资讯专栏INFORMATION COLUMN

利用JavaScript在canvas中画一棵树

sydMobile / 740人阅读

摘要:看到这个网页中在里绘制一棵树,感到很有趣,于是仿照他的源代码,同样也利用生成了一棵树。在程序中需要两个对象。中存放当前正在绘制的这一段树枝的信息,中存放的是所有的树枝。对集合内的每个元素依次进行处理这样我们就完成了在上绘制一棵树的工作。

看到这个网页中在canvas里绘制一棵树,感到很有趣,于是仿照他的源代码,同样也利用JavaScript生成了一棵树。

在程序中需要两个对象Branch, BranchCollection。Branch中存放当前正在绘制的这一段树枝的信息,BranchCollection中存放的是所有的树枝。

首先对canvas画布进行初始设置:

var width = window.innerWidth;
var height = window.innerHeight;
var canvas = document.getElementById("canvastree");
canvas.width = width;
canvas.height = height;

对初始的branch的数量、半径进行设置:

// 设置初始的数量
var n = 2 + Math.random() * 3;
// 设定初始的半径大小
var initialRadius = width / 50;

新建一个BranchCollection对象用于放置所有的branch:

branches = new BranchCollection();

这里的BranchCollection对象有如下的几个方法:

add():加入一个新元素

remove():删除一个元素

process():对集合内的每一个元素,依次调用这个元素自己的处理方法

对于创建的BranchCollection对象,将初始的branch依次加入其中,并初始化。

for (var i = 0; i < n; i++) {
    branch = new Branch();
    // 以canvas的中点为基准,左右各占一个initialRadius的宽度
    // 根据序号i算出初始x坐标
    branch.x = width/2 - initialRadius + i * 2 * initialRadius / n;
    branch.radius = initialRadius;

    // 将新的branch加入集合中去
    branches.add(branch);
}

Branch对象有这些属性:

x,y:坐标值

radius:每一条显示在屏幕上的树枝实际上都是由半径逐渐减小的圆形组合而成的,radius就是圆形的半径

angle:树枝从底部向上延伸时的角度,初始值是PI/2

speed:一个参数,用于控制树枝延伸时的速度

generation:当前的树枝是第几代,当出现分叉时,generation会加一

distance:当前的这一段树枝的长度,用于控制分叉的概率

fillStyle, shadowColor, shadowBlur:绘图参数

Branch对象的方法有:

precess():主要的处理部分,调用其它几个方法

draw():在当前的坐标处画出一个圆形

iterate():将branch向上延伸,更新坐标值,减小半径,给angle增加一个随机值

split():根据distance值判断当前是否可以分叉,如果可以则新建若干个Branch对象加入集合,并删除当前的父代对象

die():判断是否需要删除当前对象

最后通过setInterval()函数来生成图像,每隔一个时间间隔对所有branch进行一次遍历处理,画出图形,更新坐标,生成子代等。

var interval = setInterval(function() {
    // 对集合内的每个元素依次进行处理
    branches.process();
    if (branches.branches.length == 0) {
        clearInterval(interval);
    }
}, 20);

这样我们就完成了在canvas上绘制一棵树的工作。

GitHub代码地址

这里是我的一个在线的 demo

这篇原来发在我的博客上。

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/78445.html

相关文章

  • 自开发的EasyCanvas绘图库实践、Pixeler项目开发小结

    摘要:所以在此次开发中,尝试了小步快跑快速迭代的方法。开发,不仅是在开发运用上的提升,还是一个开源项目的完整实践。由于时间原因,在开发完基础版本后就去做别的项目。所以,好的文档是项目的开门钥匙。两个项目相辅相成。 showImg(https://segmentfault.com/img/bVba47g?w=900&h=150); 欢迎交换友链: laker.me--进击的程序媛Github:...

    lovXin 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<