python分形树代码_Python 3 生成漂亮的分形树图片

原标题:Python 3 生成漂亮的分形树图片

该程序通过绘制树干(最初是树;后来是树枝)并递归地添加树来绘制“树”。使用Pillow。

利用递归函数绘制分形树(fractal tree),分形几何学的基本思想:客观事物具有自相似的层次结构,局部与整体在形态、功能、信息、时间、空间等方面具有统计意义上的相似性,成为自相似性。自相似性是指局部是整体成比例缩小的性质。

版本:Python 3

# Adapted from http://rosettacode.org/wiki/Fractal_tree#Python

# to parameterise, and add colour.

# http://pillow.readthedocs.org/

# Author: Alan Richmond, Python3.codes, and others (Rosettacode)

importmath, colorsys

fromPIL importImage, ImageDraw

spread = 17# how much branches spread apart

width, height = 1000, 800# window size

maxd = 12# maximum recursion depth

len = 9.0# branch length factor

# http://pillow.readthedocs.org/en/latest/reference/Image.html

img = Image.new( 'RGB', (width, height))

# http://pillow.readthedocs.org/en/latest/reference/ImageDraw.html

d = ImageDraw.Draw(img)

# This function calls itself to add sub-trees

defdrawTree(x1, y1, angle, depth):

ifdepth > 0:

# compute this branch's next endpoint

x2 = x1 + int(math.cos(math.radians(angle)) * depth * len)

y2 = y1 + int(math.sin(math.radians(angle)) * depth * len)

# https://docs.python.org/2/library/colorsys.html

(r, g, b) = colorsys.hsv_to_rgb(float(depth) / maxd, 1.0, 1.0)

R, G, B = int( 255* r), int( 255* g), int( 255* b)

# draw the branch

d.line([x1, y1, x2, y2], (R, G, B), depth)

# and append 2 trees by recursion

drawTree(x2, y2, angle - spread, depth - 1)

drawTree(x2, y2, angle + spread, depth - 1)

# Start drawing!

drawTree(width / 2, height * 0.9, - 90, maxd)

img.show

img.save( "www.linuxidc.com.png", "PNG")

效果图如下:

关注Linux公社微信公众号( linuxidc_com),(见https://www.linuxidc.com/Linux/2013-12/93755.htm)发送“ 分形树”即可获得本文Python代码。 返回搜狐,查看更多

责任编辑:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值