热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Canvas基础教程(章节3)

这节主讲Canvas绘制贝塞尔曲线,首先我们要了解什么是贝塞尔曲线?贝塞尔曲线(Bziercurve),又称贝兹曲线或贝济埃曲线ÿ

  这节主讲 Canvas 绘制贝塞尔曲线,首先我们要了解 什么是贝塞尔曲线?

  贝塞尔曲线(Bézier curve),又称贝兹曲线或贝济埃曲线, 是应用于二维图形应用程序的数学曲线。
  一般的矢量图形软件通过它来精确画出曲线,贝兹曲线由线段与节点组成,节点是可拖动的支点,线段像可伸缩的皮筋,我们在绘图工具上看到的钢笔工具就是来做这种矢量曲线的。
  贝塞尔曲线是计算机图形学中相当重要的参数曲线,在一些比较成熟的位图软件中也有贝塞尔曲线工具如PhotoShop 等。在Flash4 中还没有完整的曲线工具,而在Flash5 里面已经提供出贝塞尔曲线工具。
  贝塞尔曲线于1962,由法国工程师皮埃尔·贝塞尔(Pierre
Bézier)所广泛发表,他运用贝塞尔曲线来为汽车的主体进行设计。贝塞尔曲线最初由Paul de Casteljau于1959年运用de Casteljau演算法开发,以稳定数值的方法求出贝兹曲线。

  啊,行了!视力不好就不要继续往下读了,来看图片吧!

一次贝塞尔曲线:
在这里插入图片描述
简单说就是一条直线。

二次贝塞尔曲线:
在这里插入图片描述
解释图:
在这里插入图片描述
红色的曲线才是形成的贝塞尔曲线。

三次贝赛尔曲线:
在这里插入图片描述
解释图:
在这里插入图片描述
红色的曲线才是贝塞尔曲线,可以看到它的弧度跟三条直线有关。


我这么通俗的解释应该都看懂了,让我们瞧瞧 Canvas 是如何绘制贝塞尔曲线的。


绘制二次贝塞尔曲线:
quadraticCurveTo(cp1x, cp1y, x, y):
参数1 和 2 控制: 控制点坐标;
参数3 和 4 控制: 终点坐标。
在这里插入图片描述
我们来做一个小小的案例:

<html>
<head>
<title>Canvas 基础title>
<style>canvas{border: 1px solid black;}
style>
head>
<body><canvas id&#61;"canvas" width&#61;"300" height&#61;"300">canvas>
body>
<script>!function(){var canvas &#61; document.getElementById(&#39;canvas&#39;);if(!canvas.getContext) return;var ctx &#61;canvas.getContext("2d");//开始代码draw();ctx.beginPath();ctx.moveTo(10,200);//起始点var cp1x &#61;40, cp1y &#61;100;//控制点var x &#61;200, y &#61;200;// 结束点//绘制二次贝塞尔曲线ctx.quadraticCurveTo(cp1x, cp1y, x, y); ctx.stroke();ctx.beginPath(); ctx.rect(10,200,10,10); ctx.rect(cp1x, cp1y,10,10); ctx.rect(x, y,10,10); ctx.fill();}()
script>
html>

  通过我们的仔细观察&#xff0c;不难看出&#xff0c;起点、终点固定&#xff0c;曲线的弧度完全是由控制点决定的&#xff0c;如图&#xff1a;在这里插入图片描述
聪明如你&#xff0c;我们来看三次贝塞尔曲线&#xff1a;

bezierCurveTo(cp1x, cp1y, cp2x, cp2y, x, y)&#xff1a;
参数1 和 2 控制&#xff1a; 控制点坐标&#xff1b;
参数3 和 4 控制&#xff1a; 控制点2的坐标&#xff1b;
参数5 和 6 控制&#xff1a; 终点的坐标。在这里插入图片描述结合案例&#xff1a;

<body><canvas id&#61;"canvas" width&#61;"300" height&#61;"300">canvas>
body>
<script>!function(){var canvas &#61; document.getElementById(&#39;canvas&#39;);if(!canvas.getContext) return;var ctx &#61;canvas.getContext("2d");//开始代码draw();ctx.beginPath();ctx.moveTo(40,200);//起始点var cp1x &#61;20, cp1y &#61;100;//控制点1 var cp2x &#61;100, cp2y &#61;120;//控制点2 var x &#61;200, y &#61;200;// 结束点//绘制三次贝塞尔曲线ctx.bezierCurveTo(cp1x, cp1y, cp2x, cp2y, x, y); ctx.stroke();ctx.beginPath(); ctx.rect(40,200,10,10); ctx.rect(cp1x, cp1y,10,10); ctx.rect(cp2x, cp2y,10,10); ctx.rect(x, y,10,10); ctx.fill();}()
script>
html>

看下控制点2的效果&#xff1a;
在这里插入图片描述
给贝塞尔曲线染色&#xff1a;
fillStyle &#61; color    设置图形的填充颜色;
strokeStyle &#61; color   设置图形轮廓的颜色。
注&#xff1a;
  1.color 可以是表示 css 颜色值的字符串、渐变对象或者图案对象。
  2.默认情况下&#xff0c;线条和填充颜色都是黑色。
  3.一旦您设置了 strokeStyle 或者 fillStyle 的值&#xff0c;那么这个新值就会成为新绘制的图形的默认值。如果你要给每个图形上不同的颜色&#xff0c;你需要重新设置 fillStylestrokeStyle 的值。

就比如&#xff1a;

<body><canvas id&#61;"canvas" width&#61;"300" height&#61;"300">canvas>
body>
<script>!function(){var canvas &#61; document.getElementById(&#39;canvas&#39;);if(!canvas.getContext) return;var ctx &#61;canvas.getContext("2d");//开始代码draw();for(var i &#61;0; i <6; i&#43;&#43;){for(var j &#61;0; j <6; j&#43;&#43;){ctx.fillStyle &#61;&#39;rgb(&#39;&#43; Math.floor(255-42.5* i)&#43;&#39;,0,&#39;&#43; Math.floor(255-42.5* j)&#43;&#39;)&#39;;ctx.fillRect(j *50, i *50,50,50);}}}()
script>
html>

效果图如下&#xff1a;
在这里插入图片描述
渐变的颜色块&#xff0c;好看吗&#xff1f;
我们来做一个更有趣的&#xff01;假设这些块快颜色是随机的&#xff0c;就好像&#xff1a;
在这里插入图片描述
那你得这样&#xff1a;

<body><canvas id&#61;"canvas" width&#61;"300" height&#61;"300">canvas>
body>
<script>!function(){var canvas &#61; document.getElementById(&#39;canvas&#39;);if(!canvas.getContext) return;var ctx &#61;canvas.getContext("2d");//开始代码draw();for(var i &#61;0; i <6; i&#43;&#43;){for(var j &#61;0; j <6; j&#43;&#43;){ctx.strokeStyle &#61;&#96;rgb(${randomInt(0,255)},${randomInt(0,255)},${randomInt(0,255)})&#96;; ctx.strokeRect(j *50, i *50,40,40);}}function randomInt(from, to){return parseInt(Math.random()*(to -from&#43;1)&#43;from);}}()
script>
html>

  我在底部定义了函数 randomInt 意为随机整数&#xff0c;请不要遗漏了它。
  然后我在想&#xff0c;有没有透明属性呢&#xff1f;
  当然&#xff0c;rgba 不算吗?
  oh no&#xff01;我指定是 Canvas 透明属性。

transparency( 透 明 度 )
  globalAlpha &#61; transparencyValue
  这个属性影响到 canvas 里所有图形的透明度&#xff0c;有效的值范围是 0.0 &#xff08;完全透明&#xff09;到 1.0&#xff08;完全不透明&#xff09;&#xff0c;默认是 1.0。
  globalAlpha 属性在需要绘制大量拥有相同透明度的图形时候相当高效。不过&#xff0c;我认为使用rgba()设置透明度更加好一些。

  这个知识点并不重要&#xff0c;但直接跳过的话应该不合适吧&#xff1f;
先弄几个小方块出来吧&#xff01;

<body><canvas id&#61;"canvas" width&#61;"300" height&#61;"300">canvas>
body>
<script>!function(){var canvas &#61; document.getElementById(&#39;canvas&#39;);if(!canvas.getContext) return;var ctx &#61;canvas.getContext("2d");//开始代码draw();ctx.fillStyle&#61;"red";ctx.fillRect(20,20,75,50);ctx.fillStyle&#61;"blue";ctx.fillRect(50,50,75,50);ctx.fillStyle&#61;"green";ctx.fillRect(80,80,75,50);}()
script>
html>

我们得到了这样三个图案:
在这里插入图片描述
加上透明度&#xff0c;就在
在哪都可以&#xff0c;加在不同的地方所起到的影响各不相同
在这里插入图片描述
 什么&#xff1f;你说看不清代码
 问我要啊&#xff01;代码又不要钱

<body><canvas id&#61;"canvas" width&#61;"300" height&#61;"300">canvas>
body>
<script>!function(){var canvas &#61; document.getElementById(&#39;canvas&#39;);if(!canvas.getContext) return;var ctx &#61;canvas.getContext("2d");//开始代码draw();ctx.globalAlpha&#61;0.2;ctx.fillStyle&#61;"red";ctx.fillRect(20,20,75,50);ctx.fillStyle&#61;"blue";ctx.fillRect(50,50,75,50);ctx.fillStyle&#61;"green";ctx.fillRect(80,80,75,50);}()
script>
html>

所以我们很容易就看出了&#xff1a;
  当透明度放在顶部时&#xff0c;影响全局&#xff0c;对整张 Canvas 画布生效&#xff1b;
  当透明度放在某一块儿元素之下时&#xff0c;仅对其及以下元素生效&#xff0c;对其之前的元素均不生效&#xff1b;
  当透明度放在函数尾部时&#xff0c;没有任何意义。代码不是按行收费的&#xff0c;为了优化请删掉它。

  Canvas 的路还有很长&#xff0c;别担心我陪你一同度过。如果前 3 章你都看完了&#xff0c;恭喜你已经可以看懂这个了&#xff1a;
“ 链接在此 ”
在这里插入图片描述
  假设你还参悟不透&#xff0c;那就看看第四章&#xff0c;反正又不要钱&#xff01;我是 “ 我不是费圆 ”&#xff0c;一个勤快的程序员。
在这里插入图片描述  前端的学习不是一蹴而就&#xff0c;不积跬步无以至千里&#xff0c;不积小流无以成江海。持续不断的努力才能让你我有所收获&#xff0c;专业的知识还得到机构去学习&#xff0c;培训机构的设立有其存在的必然性&#xff0c;你钱花对了吗&#xff1f;

推荐阅读&#xff1a;
Canvas基础教程1
Canvas基础教程2
结尾动画——线条花环


推荐阅读
  • 本文详细解析了JavaScript中相称性推断的知识点,包括严厉相称和宽松相称的区别,以及范例转换的规则。针对不同类型的范例值,如差别范例值、统一类的原始范例值和统一类的复合范例值,都给出了具体的比较方法。对于宽松相称的情况,也解释了原始范例值和对象之间的比较规则。通过本文的学习,读者可以更好地理解JavaScript中相称性推断的概念和应用。 ... [详细]
  • 在Android开发中,使用Picasso库可以实现对网络图片的等比例缩放。本文介绍了使用Picasso库进行图片缩放的方法,并提供了具体的代码实现。通过获取图片的宽高,计算目标宽度和高度,并创建新图实现等比例缩放。 ... [详细]
  • CSS3选择器的使用方法详解,提高Web开发效率和精准度
    本文详细介绍了CSS3新增的选择器方法,包括属性选择器的使用。通过CSS3选择器,可以提高Web开发的效率和精准度,使得查找元素更加方便和快捷。同时,本文还对属性选择器的各种用法进行了详细解释,并给出了相应的代码示例。通过学习本文,读者可以更好地掌握CSS3选择器的使用方法,提升自己的Web开发能力。 ... [详细]
  • sklearn数据集库中的常用数据集类型介绍
    本文介绍了sklearn数据集库中常用的数据集类型,包括玩具数据集和样本生成器。其中详细介绍了波士顿房价数据集,包含了波士顿506处房屋的13种不同特征以及房屋价格,适用于回归任务。 ... [详细]
  • 生成式对抗网络模型综述摘要生成式对抗网络模型(GAN)是基于深度学习的一种强大的生成模型,可以应用于计算机视觉、自然语言处理、半监督学习等重要领域。生成式对抗网络 ... [详细]
  • 基于layUI的图片上传前预览功能的2种实现方式
    本文介绍了基于layUI的图片上传前预览功能的两种实现方式:一种是使用blob+FileReader,另一种是使用layUI自带的参数。通过选择文件后点击文件名,在页面中间弹窗内预览图片。其中,layUI自带的参数实现了图片预览功能。该功能依赖于layUI的上传模块,并使用了blob和FileReader来读取本地文件并获取图像的base64编码。点击文件名时会执行See()函数。摘要长度为169字。 ... [详细]
  • Android中高级面试必知必会,积累总结
    本文介绍了Android中高级面试的必知必会内容,并总结了相关经验。文章指出,如今的Android市场对开发人员的要求更高,需要更专业的人才。同时,文章还给出了针对Android岗位的职责和要求,并提供了简历突出的建议。 ... [详细]
  • 本文介绍了Java工具类库Hutool,该工具包封装了对文件、流、加密解密、转码、正则、线程、XML等JDK方法的封装,并提供了各种Util工具类。同时,还介绍了Hutool的组件,包括动态代理、布隆过滤、缓存、定时任务等功能。该工具包可以简化Java代码,提高开发效率。 ... [详细]
  • 本文介绍了C#中生成随机数的三种方法,并分析了其中存在的问题。首先介绍了使用Random类生成随机数的默认方法,但在高并发情况下可能会出现重复的情况。接着通过循环生成了一系列随机数,进一步突显了这个问题。文章指出,随机数生成在任何编程语言中都是必备的功能,但Random类生成的随机数并不可靠。最后,提出了需要寻找其他可靠的随机数生成方法的建议。 ... [详细]
  • 生成对抗式网络GAN及其衍生CGAN、DCGAN、WGAN、LSGAN、BEGAN介绍
    一、GAN原理介绍学习GAN的第一篇论文当然由是IanGoodfellow于2014年发表的GenerativeAdversarialNetworks(论文下载链接arxiv:[h ... [详细]
  • [译]技术公司十年经验的职场生涯回顾
    本文是一位在技术公司工作十年的职场人士对自己职业生涯的总结回顾。她的职业规划与众不同,令人深思又有趣。其中涉及到的内容有机器学习、创新创业以及引用了女性主义者在TED演讲中的部分讲义。文章表达了对职业生涯的愿望和希望,认为人类有能力不断改善自己。 ... [详细]
  • javascript  – 概述在Firefox上无法正常工作
    我试图提出一些自定义大纲,以达到一些Web可访问性建议.但我不能用Firefox制作.这就是它在Chrome上的外观:而那个图标实际上是一个锚点.在Firefox上,它只概述了整个 ... [详细]
  • Voicewo在线语音识别转换jQuery插件的特点和示例
    本文介绍了一款名为Voicewo的在线语音识别转换jQuery插件,该插件具有快速、架构、风格、扩展和兼容等特点,适合在互联网应用中使用。同时还提供了一个快速示例供开发人员参考。 ... [详细]
  • 从零学Java(10)之方法详解,喷打野你真的没我6!
    本文介绍了从零学Java系列中的第10篇文章,详解了Java中的方法。同时讨论了打野过程中喷打野的影响,以及金色打野刀对经济的增加和线上队友经济的影响。指出喷打野会导致线上经济的消减和影响队伍的团结。 ... [详细]
  • 闭包一直是Java社区中争论不断的话题,很多语言都支持闭包这个语言特性,闭包定义了一个依赖于外部环境的自由变量的函数,这个函数能够访问外部环境的变量。本文以JavaScript的一个闭包为例,介绍了闭包的定义和特性。 ... [详细]
author-avatar
蒋筱谷_680
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有