python与分形0015 - 【教程】绘制national flag

2023-11-10 01:40

本文主要是介绍python与分形0015 - 【教程】绘制national flag,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

不知不觉,今天又周五,513330都快破6了,倒金字塔加仓都加到地下室了,真是服气了。

在前几节的教程中,我们玩了一些奇怪的事情,今天我们来玩个正经的事情,画一面五星红旗,也就是我们的国旗。

闲话不说,先上成品图。

<国旗图片>

绘制视频如下:

<国旗视频>

话不多说,还是上教程。

国旗和数学

在画国旗之前,我们需要弄清楚国旗的图形结构。

根据1949年9月28日中国人民政治协商会议第一届全体会议主席团公布的《国旗制法说明》,中华人民共和国国旗旗面为红色,长方形,其长与高为三与二之比,旗面左上方缀黄色五角星五颗。一星较大,其外接圆直径为旗高十分之三,居左;四星较小,其外接圆直径为旗高十分之一,环拱于大星之右。旗杆套为白色。

中华人民共和国国旗的红色象征革命。旗上的五颗五角星及其相互关系象征共产党领导下的革命人民大团结。五角星用黄色是为了在红地上显出光明,黄色较白色明亮美丽,四颗小五角星各有一尖正对着大星的中心点,这是表示围绕着一个中心而团结,在形式上也显得紧凑美观。

如下图所示:

<CSDN提示国旗图片违规,大家可以去查下百度百科>

我们把它转化为数学关系(假设国旗中心点为坐标系原点(0,0),每个格子长宽为L):

  1. 国旗的四个顶点为(-15L,10L),(15L,10L),(15L,-10L),(-15L,-10L)

  2. 大五角星中心点为(-10L,5L),半径为3L,水平放置

  3. 小五角星A中心点为(-5L,8L),半径为L,tan(A)=3/5

  4. 小五角星B中心点为(-3L,6L),半径为L,tan(B)=1/7

  5. 小五角星C中心点为(-3L,3L),半径为L,tan(C)=2/7

  6. 小五角星D中心点为(-5L,1L),半径为L,tan(A)=4/5

这个是我们后面绘图的基础,先放这里了。

f5ac51cd0214b67505ddad131784b73c.png

开始画图

先来画旗面,是一个简单的矩形,其思路很简单:

  1. 从左上顶点开始,往东,seth(0),走30L的长度。

  2. 再往南,seth(-90),走20L的长度。

  3. 再往西,seth(180),走30L的长度。

  4. 最后往北,seth(90),走20L的长度。

  5. fill为红色。

代码如下:

def rectangle(center, length_x, length_y, penc, fillc):turtle.pensize(1)turtle.fillcolor(fillc)turtle.pencolor(penc)turtle.up()pos=(center[0]-length_x/2, center[1]+length_y/2)turtle.goto(pos)turtle.begin_fill()turtle.down()turtle.seth(0)turtle.fd(length_x)turtle.seth(-90)turtle.fd(length_y)turtle.seth(180)turtle.fd(length_x)turtle.seth(90)turtle.fd(length_y)turtle.end_fill()

再来画五角星,我们先来分解,画一个正五角星。

同样的,我们先把数学关系弄出来,见下图:

00cb456d621484a9af970f8374205dfc.png

假设圆的半径为L。

我们先来找到边长关系,因为:sin(54) = T / L0 且 sin(36) = T / L,得到:L0 = L * sin(36) / sin(54),即五角星的边长。

我们观察到五角星的边具有可复制性,A-C1-B重复画5次即可,那么我们先把A-C1-B画出来。

  1. 先不要下笔,从O出发,向北,seth(90),走L的长度,现在在A点。

  2. 向西南方向,seth(180+72),做准备。

  3. 落笔,走L0的长度,到C1点。

  4. 右转72度,right(72),走L0的长度,到B点。

  5. 至此,A-C1-B就画好了。

  6. 然后我们把方向转到下一次画图的方向,左转144度,left(144)。

  7. 重复3-6的动作4次,即可完成整个图形。

  8. 最后fill为黄色。

代码如下:

def star(pos, length, penc, fillc):turtle.pensize(1)turtle.fillcolor(fillc)turtle.pencolor(penc)L = length*math.sin(36*math.pi/180)/math.sin(54*math.pi/180)turtle.up()turtle.goto(pos)turtle.seth(90)turtle.fd(length)turtle.seth(180+72)turtle.down()turtle.begin_fill()for _ in range(5):turtle.fd(L)turtle.right(72)turtle.fd(L)turtle.left(144)turtle.end_fill()
d261bfaa35a6898f51d1e886c8bf6de4.gif

五角星我们已经画出来了,现在我们需要给它旋转一个角度。

这时,我们发现,绘图的过程中,五角星的角度在down之前就已经调整好了,后面画5条折线的时候都是相对位置。

OK,我们把函数改吧改吧就可以了:

def star(pos, angle, length, penc, fillc):turtle.pensize(1)turtle.fillcolor(fillc)turtle.pencolor(penc)L = length*math.sin(36*math.pi/180)/math.sin(54*math.pi/180)turtle.up()turtle.goto(pos)turtle.seth(90+angle)turtle.fd(length)turtle.seth(180+72+angle)turtle.down()turtle.begin_fill()for _ in range(5):turtle.fd(L)turtle.right(72)turtle.fd(L)turtle.left(144)turtle.end_fill()

再来看,旋转20°:

star((0, 0), 0, 90, 'yellow', 'yellow')
star((150, 0), 20, 90, 'red', 'red')
23f372daf5fe80c602b8bbb096d0c6b2.gif

OK,到此,万事俱备,只欠代码。

画国旗

所有的细节都说清楚了,直接上代码吧!!!

#coding: utf-8import turtle
import time
import mathturtle.setup(width=1.0, height=1.0, startx=None, starty=None)
turtle.ht()
turtle.tracer(0, 0)
turtle.bgcolor("black")turtle.pensize(1)def star(center, angle, length, penc, fillc):turtle.pensize(1)turtle.fillcolor(fillc)turtle.pencolor(penc)L = length*math.sin(36*math.pi/180)/math.sin(54*math.pi/180)    turtle.up()turtle.goto(center)turtle.seth(90+angle)turtle.fd(length)turtle.seth(180+72+angle)turtle.down()turtle.begin_fill()for _ in range(5):turtle.fd(L)turtle.right(72)turtle.fd(L)turtle.left(144)turtle.end_fill()def rectangle(center, length_x, length_y, penc, fillc):turtle.pensize(1)turtle.fillcolor(fillc)turtle.pencolor(penc)turtle.up()pos=(center[0]-length_x/2, center[1]+length_y/2)turtle.goto(pos)turtle.begin_fill()turtle.down()turtle.seth(0)turtle.fd(length_x)turtle.seth(-90)turtle.fd(length_y)turtle.seth(180)turtle.fd(length_x)turtle.seth(90)turtle.fd(length_y)turtle.end_fill()W = 1200
H = 800
dW = W/30
dH = H/20#time.sleep(6)rectangle((0,0), W, H, 'red', 'red')
C0 = (-dW*10, dH*5)
A0 = 0
L0 = dW*3
star(C0, A0, L0, 'yellow', 'yellow')
C1 = (-dW*5, dH*8)
A1 = 90+math.atan(3/5)*180/math.pi
L1 = dW
star(C1, A1, L1, 'yellow', 'yellow')
C2 = (-dW*3, dH*6)
A2 = 90+math.atan(1/7)*180/math.pi
L2 = dW
star(C2, A2, L2, 'yellow', 'yellow')
C3 = (-dW*3, dH*3)
A3 = 90-math.atan(2/7)*180/math.pi
L3 = dW
star(C3, A3, L3, 'yellow', 'yellow')
C4 = (-dW*5, dH)
A4 = 90-math.atan(4/5)*180/math.pi
L4 = dW
star(C4, A4, L4, 'yellow', 'yellow')
c83aff18d6398f07d84e4ed8cb575122.gif 3e12dd1dad642699af36b57e9db412bc.png b775b5daa8087bf7abe208c62ce3fe52.gif

这篇关于python与分形0015 - 【教程】绘制national flag的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/379667

相关文章

SpringBoot集成redisson实现延时队列教程

《SpringBoot集成redisson实现延时队列教程》文章介绍了使用Redisson实现延迟队列的完整步骤,包括依赖导入、Redis配置、工具类封装、业务枚举定义、执行器实现、Bean创建、消费... 目录1、先给项目导入Redisson依赖2、配置redis3、创建 RedissonConfig 配

Python的Darts库实现时间序列预测

《Python的Darts库实现时间序列预测》Darts一个集统计、机器学习与深度学习模型于一体的Python时间序列预测库,本文主要介绍了Python的Darts库实现时间序列预测,感兴趣的可以了解... 目录目录一、什么是 Darts?二、安装与基本配置安装 Darts导入基础模块三、时间序列数据结构与

Python正则表达式匹配和替换的操作指南

《Python正则表达式匹配和替换的操作指南》正则表达式是处理文本的强大工具,Python通过re模块提供了完整的正则表达式功能,本文将通过代码示例详细介绍Python中的正则匹配和替换操作,需要的朋... 目录基础语法导入re模块基本元字符常用匹配方法1. re.match() - 从字符串开头匹配2.

Python使用FastAPI实现大文件分片上传与断点续传功能

《Python使用FastAPI实现大文件分片上传与断点续传功能》大文件直传常遇到超时、网络抖动失败、失败后只能重传的问题,分片上传+断点续传可以把大文件拆成若干小块逐个上传,并在中断后从已完成分片继... 目录一、接口设计二、服务端实现(FastAPI)2.1 运行环境2.2 目录结构建议2.3 serv

通过Docker容器部署Python环境的全流程

《通过Docker容器部署Python环境的全流程》在现代化开发流程中,Docker因其轻量化、环境隔离和跨平台一致性的特性,已成为部署Python应用的标准工具,本文将详细演示如何通过Docker容... 目录引言一、docker与python的协同优势二、核心步骤详解三、进阶配置技巧四、生产环境最佳实践

Python一次性将指定版本所有包上传PyPI镜像解决方案

《Python一次性将指定版本所有包上传PyPI镜像解决方案》本文主要介绍了一个安全、完整、可离线部署的解决方案,用于一次性准备指定Python版本的所有包,然后导出到内网环境,感兴趣的小伙伴可以跟随... 目录为什么需要这个方案完整解决方案1. 项目目录结构2. 创建智能下载脚本3. 创建包清单生成脚本4

Python实现Excel批量样式修改器(附完整代码)

《Python实现Excel批量样式修改器(附完整代码)》这篇文章主要为大家详细介绍了如何使用Python实现一个Excel批量样式修改器,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一... 目录前言功能特性核心功能界面特性系统要求安装说明使用指南基本操作流程高级功能技术实现核心技术栈关键函

python获取指定名字的程序的文件路径的两种方法

《python获取指定名字的程序的文件路径的两种方法》本文主要介绍了python获取指定名字的程序的文件路径的两种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 最近在做项目,需要用到给定一个程序名字就可以自动获取到这个程序在Windows系统下的绝对路径,以下

使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解

《使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解》本文详细介绍了如何使用Python通过ncmdump工具批量将.ncm音频转换为.mp3的步骤,包括安装、配置ffmpeg环... 目录1. 前言2. 安装 ncmdump3. 实现 .ncm 转 .mp34. 执行过程5. 执行结

Python实现批量CSV转Excel的高性能处理方案

《Python实现批量CSV转Excel的高性能处理方案》在日常办公中,我们经常需要将CSV格式的数据转换为Excel文件,本文将介绍一个基于Python的高性能解决方案,感兴趣的小伙伴可以跟随小编一... 目录一、场景需求二、技术方案三、核心代码四、批量处理方案五、性能优化六、使用示例完整代码七、小结一、