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

编程画出千姿百态的树叶

编程画出千姿百态的树叶作者:安徽省亳州三中教科处王宇邮编:236800
编程画出千姿百态的树叶
作者:安徽省亳州三中教科处王宇    邮编:236800      E-Mail: Wydz511@sohu.com   
 
走到户外,欣赏大自然的美景,映入眼帘的是千姿百态,各种各样美丽的树。这不禁使人在心旷神怡之余开始赞叹大自然的伟大。于是就有了用电脑把这美景画出来的冲动。
 
经过一番探索,程序编出来了,画出的效果还真不少,如图 1 所示,笔者根据其形状命名的有蕨叶、芦苇、叶脉、文竹、大树、嫩藤、小草、葡萄、迎客松、玫瑰花、五星花、蒲公英、塔、羽毛、凤凰、孔雀、浪花、稻草人等。
 
           
  
 仔细观察它们的形状有何规律,那就是自相似性,一棵树分的一个叉又是一棵小树。
 
 为了说明原理,笔者以二维情况下非常典型的一棵小树为例来介绍画图的算法。
 
  设这棵树发了两个叉,如图 2 深色部分所示。沿着箭头的方向,画这棵树需要如下步骤。
 
首先从起点开始向前走到第一个分叉点,设距离是L1
 
②向左转θ 1
 
③画子树;
 
④向右转回θ 1 ,然后再向左转 θ,这个θ角相当于树的曲度;
 
⑤继续向前走 到第二个分叉点,又走了L2
 
⑥向右转θ 2
 
⑦画子树;
 
⑧向左转θ 2 ,考虑到如果树枝下面还有枝节,应该再向左多转 θ表示树的曲度;
 
⑨向右转回θ,后退L2,回到 第二个分叉点
 
⑩向右转回θ,后退L1,回到起点。
 
至此一棵完整的树就诞生了。
 
算法分析:在算法中,③、⑦用到了递归方法,对自身进行调用,正是这一步骤模拟了自然界树木生长的实质。⑨、 ⑩两个步骤为回溯算法,保证画完子树之后能退回到 转弯时的出发点。
 
对于一般的情况程序核心代码如下:
 
Sub leaf(ByVal n As Integer, ByVal l As Single)
' 蕨叶(n为递归深度,大小为L )蕨叶和树结构类似
Dim i As Integer 'i 是循环变量
If n = 0 Then Exit Sub ' 递归的结束条件
  For i = branch To 1 Step -1 'branch 指枝条数
    FD L1 * i / branch * l 
    LT Seta1
    leaf n - 1, i / branch * l / K1 ' 左子树大小的比例系数为 K1
    RT Seta1 – Seta ' 树的曲度为 Seta
    FD L2 * i / branch * l
    RT Seta2
    leaf n - 1, i / branch * l / K2 ' 右子树大小的比例系数为 K2
    LT Seta2 + Seta
  Next i
  For i = 1 To branch    ' 回溯主叶干
    RT Seta
    BK L2 * i / branch * l
    RT Seta
    BK L1 * i / branch * l
  Next i
End Sub
 
程序说明:
 
本程序为多枝条树的画法,主要是用递归和循环来描述的。对于程序究竟是怎么执行的,聪明的你还需要动脑去想一想,这可是使你更加深刻的理解递归和循环的好机会啊。
 
在程序中调用了一些称为海龟作图的函数,假设有一只听话的小海龟在受你的控制,它能听懂如下命令: FD n,在当前位置上前进n步;BK n,在当前位置上后退n步;RT n,在当前位置上向右转n度;LT n,在当前位置上向左转n度。这些函数用VB的Line 语句很好实现,这里就不再详细介绍了。
 
代码可能比较枯燥,但看着这些美丽的效果你就会感受到编程的无穷乐趣了。
 
程序界面如图 3 所示:
 
在程序运行时可以方便的调节各个参数,通过调整比例系数可以改变子树的大小,从而决定画出的形状更像是树之还是树叶;调整子树的倾斜角度可以形成不同的树种;在各个参数中曲度对树的形状影响最大,调整它可以生成不同类别的图案。使用动画按钮还可观察到一个树叶从小到大的生长过程。
 
通过编程画出了这些千姿百态的树形图案,这些图案也许从几何层面上揭示了自然界的生物生长、海浪等现象的原理,那就是整体是由自身的部分不断复制而形成的。
 
对程序的拓广:
 
如果增加三维功能,则可描绘出更加逼真的树图。
 
只要稍微变换一下规则,还可画出各种类似具有分形规律的图形。
 
赶快动手吧,大自然蕴含的无穷规律正等待我们去不断探索,不断发现。
 

程序下载页面蕨叶生成器

本文已发表在《电脑报》2005年12期(2005.4.16),并收入2005《电脑报》合订本。
 
作品名称:编程画出千姿百态的树叶
程序名称:蕨叶生成器
制作日期: 2005.2.16
邮编: 236800
作者 E-Mail: Wydz511@sohu.com  
QQ 84115144

推荐阅读
  • 本文详细介绍了 SVN 中的 switch 命令及其使用方法,包括如何切换工作副本到新的 URL 和如何处理版本库迁移等情况。 ... [详细]
  • 2023年京东Android面试真题解析与经验分享
    本文由一位拥有6年Android开发经验的工程师撰写,详细解析了京东面试中常见的技术问题。涵盖引用传递、Handler机制、ListView优化、多线程控制及ANR处理等核心知识点。 ... [详细]
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • 本文将介绍如何编写一些有趣的VBScript脚本,这些脚本可以在朋友之间进行无害的恶作剧。通过简单的代码示例,帮助您了解VBScript的基本语法和功能。 ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • C++实现经典排序算法
    本文详细介绍了七种经典的排序算法及其性能分析。每种算法的平均、最坏和最好情况的时间复杂度、辅助空间需求以及稳定性都被列出,帮助读者全面了解这些排序方法的特点。 ... [详细]
  • 本文详细探讨了Java中的24种设计模式及其应用,并介绍了七大面向对象设计原则。通过创建型、结构型和行为型模式的分类,帮助开发者更好地理解和应用这些模式,提升代码质量和可维护性。 ... [详细]
  • 深入理解C++中的KMP算法:高效字符串匹配的利器
    本文详细介绍C++中实现KMP算法的方法,探讨其在字符串匹配问题上的优势。通过对比暴力匹配(BF)算法,展示KMP算法如何利用前缀表优化匹配过程,显著提升效率。 ... [详细]
  • 机器学习中的相似度度量与模型优化
    本文探讨了机器学习中常见的相似度度量方法,包括余弦相似度、欧氏距离和马氏距离,并详细介绍了如何通过选择合适的模型复杂度和正则化来提高模型的泛化能力。此外,文章还涵盖了模型评估的各种方法和指标,以及不同分类器的工作原理和应用场景。 ... [详细]
  • 自学编程与计算机专业背景者的差异分析
    本文探讨了自学编程者和计算机专业毕业生在技能、知识结构及职业发展上的不同之处,结合实际案例分析两者的优势与劣势。 ... [详细]
  • 深入理解Git与GitHub:分支管理与冲突解决
    本文详细探讨了Git中的分支管理技术,包括如何创建、切换和合并分支,以及如何有效解决分支合并时可能遇到的冲突。同时,文章还介绍了Git的基本原理,如哈希算法的应用和文件管理机制。 ... [详细]
  • 构建Python自助式数据查询系统
    在现代数据密集型环境中,业务团队频繁需要从数据库中提取特定信息。为了提高效率并减少IT部门的工作负担,本文探讨了一种利用Python语言实现的自助数据查询工具的设计与实现。 ... [详细]
  • 视觉Transformer综述
    本文综述了视觉Transformer在计算机视觉领域的应用,从原始Transformer出发,详细介绍了其在图像分类、目标检测和图像分割等任务中的最新进展。文章不仅涵盖了基础的Transformer架构,还深入探讨了各类增强版Transformer模型的设计思路和技术细节。 ... [详细]
  • 本文将深入探讨 Unreal Engine 4 (UE4) 中的距离场技术,包括其原理、实现细节以及在渲染中的应用。距离场技术在现代游戏引擎中用于提高光照和阴影的效果,尤其是在处理复杂几何形状时。文章将结合具体代码示例,帮助读者更好地理解和应用这一技术。 ... [详细]
  • 本文介绍如何解决在 IIS 环境下 PHP 页面无法找到的问题。主要步骤包括配置 Internet 信息服务管理器中的 ISAPI 扩展和 Active Server Pages 设置,确保 PHP 脚本能够正常运行。 ... [详细]
author-avatar
迈迈最love
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有