HTML5 学习手笔二:canvas API 绘制树形图案A
admin
2023-06-12 00:41:48
0

 上篇通过对canvas 画对角线,了解了一些canvas画图基本原理。现在可以利用HTML5 canvas API创建一个场景:带有长跑跑道的树林。

本篇大纲

 

  1. 用canvas API绘制树木的树冠
  2. 为树冠的边框架加粗并且填充树冠颜色
  3. 为树冠创造一个强大的树干
  4. 绘制跑道 

用canvas API绘制树木的树冠

原理还是与上篇画对角线一样,只是步骤增多而已,先看代码:

 

   
                function createCanopyPath(context){
                  context.beginPath();
                  
                 context.moveTo(-25,-50);
                 context.lineTo(-10,-80);
                 context.lineTo(-20,-80);
                 context.lineTo(-5,-110);
                 context.lineTo(-15,-110);

                 context.lineTo(0,-140);

                 context.lineTo(15,-110);
                 context.lineTo(5,-110);
                 context.lineTo(20,-80);
                 context.lineTo(10,-80);
                 context.lineTo(25,-50);

                 context.closePath();
                }

        function drawTrails(){
                var canvas=document.getElementById('diagonal');
                var context=canvas.getContext('2d');
                
                context.save();
                context.translate(130,250);
                
                createCanopyPath(context);
                context.stroke();
                context.restore();
        }
 window.addEventListener("load",drawTrails,true);
         复制代码

DEMO效果如下:

上面的代码中有一个特殊的函数叫做closePath。这个函数的行为同lineTo很像,唯一的差别在于closePath会将路径的起始坐标自动作为目标坐标。closePath还会通知canvas当前绘制的图形己经闭合或者形成了完全封闭的区域。

 

 为树冠的边框架加粗并且填充树冠颜色

 为了使树冠更加形象并且看起来像真的树,不得不利用canvas 的API绘制其图形外观,代码如下:

 

  function drawTrails(){
                var canvas=document.getElementById('diagonal');
                var context=canvas.getContext('2d');
                
                context.save();
                context.translate(130,250);
                
                createCanopyPath(context);
                //加宽线条
                context.lineWidth=4;
                //平滑路径的接合点
                context.lineJoin='round';
                //将颜色改成棕色
                context.strokeStyle='#663300';
                
                //将填充色设置为绿色并填充树冠
                context.fillStyle='#339900';
                context.fill();
        
                context.stroke();
                context.restore();
        } 复制代码

 

 DEMO效果见下面运行效果:

lineJoin属性设置为round,这是修改当前形状中线段的连接方式,让拐角变得更加油;也可以把lineJoin属性设置成bevel或者miter来变换拐角样式。

strokeStyle属性是为了改变线条颜色。

fillStyle属性是为了设置填充颜色

context 的fill 函数是为了可以让canvas对当前图形中所有的闭合路径内部的像素点进行填充,配合fillStyle 填充内部像形点颜色。

 

 为树冠创造一个强大的树干

创建树干有两种方法

 

  1. 用我们上面学过的使用线条然后配合closePath画树干
  2. HTML5 提供了一个强大的填充矩形的函数 fillRect 可以画一块矩形x轴、y轴、需要画的宽度和高度即可 

 

在这里我们使用fillRect 来构建树干。代码如下:

 

 context.fillStyle='#663300';
                context.fillRect(-5,-50,10,50); 复制代码

 

 效果DEMO如下:

  

与fillRect相关的函数还有:strokeRect和clearRect。strokeRect的作用是基于给出的位置和坐标画出矩形的轮廓,clearRect的作用是清除矩形区域内的所有内容并将它恢复到初始状态,即透明。

 

 

 绘制跑道 

 完成本篇最后一个功能,在小树旁边画上一个跑道。代码如下:

 function drawTrails(){
                var canvas=document.getElementById('diagonal');
                var context=canvas.getContext('2d');
                
                context.save();
                context.translate(130,250);
                
                createCanopyPath(context);
                //加宽线条
                context.lineWidth=4;
                //平滑路径的接合点
                context.lineJoin='round';
                //将颜色改成棕色
                context.strokeStyle='#663300';
                
                //将填充色设置为绿色并填充树冠
                context.fillStyle='#339900';
                context.fill();
                
                context.fillStyle='#663300';
                context.fillRect(-5,-50,10,50);
        
                context.stroke();
                context.restore();

                context.save();
                context.translate(-10,350);
                context.beginPath();
                context.moveTo(0,0);
                //第一条曲线向右上方弯曲
                context.quadraticCurveTo(170,-50,260,-190);
                //第二条曲线向右下方弯曲
                context.quadraticCurveTo(310,-250,410,-250);
                context.strokeStyle='#663300';
                context.lineWidth=20;
                context.stroke();
                context.restore();
        }  复制代码

quadraticCurveTo函数绘制曲线的起点是当前坐标,带有两组(x,y)参数。第二组是指曲线的终点。第一组代表控制点。所谓的控制点位于曲线的旁边,其作用相当于对曲线产生一个拉力。通过高速控制点的位置,就可以改变曲线的曲率。在右上方再画一条一样的曲线,以形成一条路。DEMO效果如下:

 

与quadraticCureTo函数一样的曲线功能还涉及:bezierCurveTo、arcTo和arc函数。这些函数通过多种控制点(如半径、角度和等)让曲线更具可塑性。

 

本文参考自:pro HTML5 Programming. 

相关内容

热门资讯

华为正式发表半导体领域“新定律... 据凤凰卫视报道,5月25日,2026国际电路与系统研讨会在上海举行,华为公司董事、半导体业务部总裁何...
满身泥浆的他闪闪发光 持续强降雨致山洪暴发,云南某村小组长田如良带领全村群众安全转移,自己却一度被泥石流吞没,成了“泥人守...
山西矿难的根源在哪里?学者吁打... 据凤凰卫视报道,沁源发生特大煤矿瓦斯爆炸事故后,山西决定对全省煤矿领域展开安全风险的“彻查整治”。有...
俄方称将对基辅军工联合体发动打... △基辅(资料图)当地时间25日,俄罗斯外交部发布通报称,俄军将对乌克兰首都基辅的军工联合体发动一系列...
深耕特色兴实业 因地制宜谱新篇 近期,全国各地立足资源禀赋、深耕产业赛道,处处涌动着产业升级、增收致富的蓬勃生机。 向新攀登 河南跑...
荣耀600全系搭载教科书级护眼... 快科技5月25日消息,荣耀600系列于今晚正式发布,全系配备教科书级护眼屏。 据悉,荣耀600系列首...
近万“青鸟”上街参加挺军购游行... 海峡导报综合报道 为抗议在野阵营通过7800亿元(新台币,下同)特别预算,台湾亲绿民团23日下午发起...
华为公布半导体领域重大突破 5月25日,2026国际电路与系统研讨会在上海举行,华为公司董事、半导体业务部总裁何庭波在题为《半导...
全焦段4K实况照片+8000m... 一、前言:全能无短板!荣耀600 Pro闪亮登场 现如今的中高端手机市场,可以说是卷得五花八门。大家...
强烈信号,家长们现在要连夜排队... 北京家长凌晨3点排队,只为孩子能上个中职学校。5月10日这天,是北京昌平职业技术学校自主招生面试日:...