Python3使用turtle绘制超立方体图形示例
作者:逆转流年 时间:2021-02-01 14:21:07
本文实例讲述了Python3使用turtle绘制超立方体图形。分享给大家供大家参考,具体如下:
利用Python3中turtle的绘制超立方体。
绘图思路:
1)求出边长100的超立方体的点坐标;
以竖直线为依据,将点分为上下两组:
a为上边点列表,b为下边点列表:
a = [[120.71, 50], [50, 120.71], [-50, 120.71], [-120.71, 50], [-50, -20.71], [50, -20.71], [20.71, 50],[-20.71, 50]]
b = [[120.71, -50], [50, 20.71], [-50, 20.71], [-120.71, -50], [-50, -120.71], [50, -120.71], [20.71, -50],[-20.71, -50]]
2)编写绘制直线函数;
3)编写主程序:绘制点,绘制六角形直线,绘制竖直直线,绘制斜线
代码片段如下,可能不是最简洁的,如有好的建议,请不吝指正。
import turtle
# 创建绘制直线函数
def drawLine(p1, p2, size=3, color="black"):
turtle.penup()
turtle.goto(p1)
turtle.pensize(size)
turtle.pencolor(color)
turtle.pendown()
turtle.goto(p2)
def main():
# 求取点后,将超立方体点分为上下两个部分,两个列表
a = [[120.71, 50], [50, 120.71], [-50, 120.71], [-120.71, 50], [-50, -20.71], [50, -20.71], [20.71, 50],
[-20.71, 50]]
b = [[120.71, -50], [50, 20.71], [-50, 20.71], [-120.71, -50], [-50, -120.71], [50, -120.71], [20.71, -50],
[-20.71, -50]]
# 绘制点
turtle.pencolor("red")
turtle.penup()
for i in range(len(a)):
turtle.goto(a[i])
turtle.down()
turtle.dot(10, "red")
turtle.penup()
for i in range(len(b)):
turtle.goto(b[i])
turtle.down()
turtle.dot(10, "red")
turtle.penup()
# 绘制六边形直线
for i in range(6):
if i <= 4:
drawLine(a[i], a[i + 1])
drawLine(b[i], b[i + 1])
else:
drawLine(a[i], a[0])
drawLine(b[i], b[0])
# 绘制竖直线
for i in range(len(a)):
drawLine(a[i], b[i])
# 绘制斜线
drawLine(a[6], a[0])
drawLine(a[6], a[2])
drawLine(a[6], a[4])
drawLine(a[7], a[1])
drawLine(a[7], a[3])
drawLine(a[7], a[5])
drawLine(b[6], b[0])
drawLine(b[6], b[2])
drawLine(b[6], b[4])
drawLine(b[7], b[1])
drawLine(b[7], b[3])
drawLine(b[7], b[5])
turtle.done()
if __name__ == '__main__':
main()
pass
运行结果:
注:使用eclipse+pyDev结合Python3环境开发时,会提示:Undefined variable from import: penup及Undefined variable from import: goto等错误,无需理会直接运行仍可绘制出该图形。
希望本文所述对大家Python程序设计有所帮助。
来源:https://blog.csdn.net/cccshare/article/details/78170322
标签:Python,turtle,绘制
0
投稿
猜你喜欢
在notepad++中实现直接运行python代码
2022-08-19 09:52:00
Python使用ffmpy将amr格式的音频转化为mp3格式的例子
2021-06-14 13:50:07
教你如何用Python实现人脸识别(含源代码)
2021-03-14 23:33:03
合理设置内存让数据库与其他程序共存
2009-05-21 16:24:00
python中封包建立过程实例
2021-11-13 14:29:08
图片预加载效果的实现
2008-06-16 12:08:00
按钮上的内容
2007-11-27 00:13:00
python中plt.imshow与cv2.imshow显示颜色问题
2023-12-13 10:47:54
python实现从ftp上下载文件的实例方法
2021-04-24 16:37:02
OpenSearch 初探
2008-06-19 12:06:00
如何限制上传文件的大小?
2010-06-09 18:47:00
用asp实现的获取文件夹中文件的个数的代码
2011-03-08 11:02:00
初学者学习Python好还是Java好
2021-03-16 21:48:32
Python获取航线信息并且制作成图的讲解
2023-08-28 18:18:56
Pytest实现setup和teardown的详细使用详解
2023-09-12 02:06:48
Python实现全局变量的两个解决方法
2021-03-23 22:43:44
试了下Golang实现try catch的方法
2023-07-21 20:49:59
Python设计模式之工厂模式简单示例
2022-10-06 13:22:38
Python Tensor FLow简单使用方法实例详解
2022-01-01 16:55:44
《写给大家看的设计书》阅读笔记之对比原则
2009-07-15 10:14:00