提到太阳系,大家可能会想到哥白尼和他的日心说,或是捍卫、发展日心说的斗士布鲁诺,他们像一缕光一样照亮了那个时代的夜空,对历史感兴趣的小伙伴可以深入了解一下,这里就不多说了。

太阳以巨大的引力使周边行星、卫星等绕其运转,构成了太阳系,它主要包括太阳、8 个行星、205 个卫星以及几十万个小行星等,本文我们使用 Python 来简单的动态模拟一下太阳系的运转。

实现

功能的实现,主要要到的还是 Python 的 pygame 库,我们先导入需要的所有 Python 库,代码如下所示:import sysimport mathimport pygamefrom pygame.locals import *

接着定义一些常量(如:颜色、宽高等)及创建窗口,代码如下所示:WHITE =(255, 255, 255)SILVER = (192, 192, 192)BLACK = (0, 0, 0)GREEN = (0, 255, 0)RED = (255, 0, 0)BLUE = (0, 0, 255)YELLOW = (255, 255, 0)SandyBrown = (244, 164, 96)PaleGodenrod = (238, 232, 170)PaleVioletRed = (219, 112, 147)Thistle = (216, 191, 216)size = width, height = 800, 600screen = pygame.display.set_mode(size)pygame.display.set_caption("太阳系")# 创建时钟(控制游戏循环频率)clock = pygame.time.Clock()# 定义三个空列表pos_v = pos_e = pos_mm = []# 地球、月球等行星转过的角度roll_v = roll_e = roll_m = 0roll_3 = roll_4 = roll_5 = roll_6 = roll_7 = roll_8 = 0# 太阳的位置(中心)position = size[0] // 2, size[1] // 2

我们先在窗口中画一个太阳,代码如下:pygame.draw.circle(screen, YELLOW, position, 60, 0)

看一下效果:

接着画一个地球,让其绕着太阳旋转,代码如下:# 画地球roll_e += 0.01 # 假设地球每帧公转 0.01 pipos_e_x = int(size[0] // 2 + size[1] // 6 * math.sin(roll_e))pos_e_y = int(size[1] // 2 + size[1] // 6 * math.cos(roll_e))pygame.draw.circle(screen, BLUE, (pos_e_x, pos_e_y), 15, 0)# 地球的轨迹线pos_e.append((pos_e_x, pos_e_y))if len(pos_e) > 255:pos_e.pop(0)for i in range(len(pos_e)):pygame.draw.circle(screen, SILVER, pos_e[i], 1, 0)

看一下效果:

我们再接着画月球,代码如下:# 画月球roll_m += 0.1pos_m_x = int(pos_e_x + size[1] // 20 * math.sin(roll_m))pos_m_y = int(pos_e_y + size[1] // 20 * math.cos(roll_m))pygame.draw.circle(screen, SILVER, (pos_m_x, pos_m_y), 8, 0)# 月球的轨迹线pos_mm.append((pos_m_x, pos_m_y))if len(pos_mm) > 255:pos_mm.pop(0)for i in range(len(pos_mm)):pygame.draw.circle(screen, SILVER, pos_mm[i], 1, 0)

看一下效果:

其他几个星球的实现也类似,代码如下:# 其他几个行星roll_3 += 0.03pos_3_x = int(size[0] // 2 + size[1] // 3.5 * math.sin(roll_3))pos_3_y = int(size[1] // 2 + size[1] // 3.5 * math.cos(roll_3))pygame.draw.circle(screen, GREEN, (pos_3_x, pos_3_y), 20, 0)roll_4 += 0.04pos_4_x = int(size[0] // 2 + size[1] // 4 * math.sin(roll_4))pos_4_y = int(size[1] // 2 + size[1] // 4 * math.cos(roll_4))pygame.draw.circle(screen, SandyBrown, (pos_4_x, pos_4_y), 20, 0)roll_5 += 0.05pos_5_x = int(size[0] // 2 + size[1] // 5 * math.sin(roll_5))pos_5_y = int(size[1] // 2 + size[1] // 5 * math.cos(roll_5))pygame.draw.circle(screen, PaleGodenrod, (pos_5_x, pos_5_y), 20, 0)roll_6 += 0.06pos_6_x = int(size[0] // 2 + size[1] // 2.5 * math.sin(roll_6))pos_6_y = int(size[1] // 2 + size[1] // 2.5 * math.cos(roll_6))pygame.draw.circle(screen, PaleVioletRed, (pos_6_x, pos_6_y), 20, 0)roll_7 += 0.07pos_7_x = int(size[0] // 2 + size[1] // 4.5 * math.sin(roll_7))pos_7_y = int(size[1] // 2 + size[1] // 4.5 * math.cos(roll_7))pygame.draw.circle(screen, Thistle, (pos_7_x, pos_7_y), 20, 0)roll_8 += 0.08pos_8_x = int(size[0] // 2 + size[1] // 5.5 * math.sin(roll_8))pos_8_y = int(size[1] // 2 + size[1] // 5.5 * math.cos(roll_8))pygame.draw.circle(screen, WHITE, (pos_8_x, pos_8_y), 20, 0)

最后,我们来看一下整体实现的动态效果:

是不是有内味了。

总结

本文我们使用 Python 简单模拟了太阳系的运转,有兴趣的小伙伴可以自己运行一下代码或对功能做进一步扩展。

用python画太阳系_用 Python 动态模拟太阳系运转相关推荐

  1. 用python画风车_用Python画小女孩放风筝的示例

    我就废话不多说了,直接上代码吧! # coding:utf-8 2import turtle as t 3import random 4# 画心 5def xin(): 6 def curvemove ...

  2. 用python画圆锥_用python画一幅美瞳,今日份来自程序员的浪漫

    如果说,眼睛是心灵的窗户,那么,美瞳就是心灵的彩窗,就像下图中这样. 而我们今天所要挑战的,就是用python画美瞳,而且是五分钟之内画三百副争奇斗艳.各领风骚.绝不重样的美瞳.作为这颗地球上最纯情的 ...

  3. 怎么用python画房子_用python画一个小房子

    用python画一个小房子 2020年07月22日 | 萬仟网IT编程 | 我要评论 如何用python画一个小房子?效果图如下:代码如下:import turtle# 前置p = turtle.Pe ...

  4. python turtle画房子代码里面的窗子,如何用python画房子_用python画一个小房子

    如何用python画一个小房子? 效果图如下: 代码如下: import turtle # 前置 p = turtle.Pen() # 作者要说的话 for i in range(6): print( ...

  5. 用python画佩奇_使用python画个小猪佩奇的示例代码

    基本原理 选好画板大小,设置好画笔颜色.粗细,定位好位置,依次画鼻子.头.耳朵.眼睛.腮.嘴.身体.手脚.尾巴,完事儿. 都知道,Turtle 是 Python 内置的一个比较有趣味的模块,俗称&qu ...

  6. 用python画皇冠_用python做数字油画或者从一幅画学习风格,去画另一幅画

    原博文 2018-08-30 17:12 − 1. 用python做数字油画 模块: pillow 2. 从一幅画学习风格,去画另一幅画 http://pytorch.org/tutorials/ad ...

  7. 利用python画曲线_利用python画出AUC曲线的实例

    以load_breast_cancer数据集为例,模型细节不重要,重点是画AUC的代码.1XS免费资源网 直接上代码:1XS免费资源网 from sklearn.datasets import loa ...

  8. 利用python画曲线_利用Python绘制血药浓度-时间曲线——口服吸收一室模型

    血药浓度-时间曲线一般是通过拟合所测定的血药浓度点而画出来的,但是在某些时候,如阅读文献时,我们需要根据别人报道的PK参数来画出药时曲线.Python语法简单,拥有丰富的开源库,下面尝试通过Pytho ...

  9. 用python画明星_用Python画一颗特别的心送给她

    [前言] 520刚过去了,大家有没有跟自己喜欢的对象在一起呢? 520 当天你还在送 玫瑰花?巧克力?情侣套装?... 小编就想说:你能不能换点新意呢,这些操作已经普通的不能再普通了吧!就像别人来例假 ...

  10. python画雪_用Python画一棵带音乐的雪夜圣诞树

    本文我们用 Python 来画一棵带音乐效果的雪夜圣诞树,基本思路如下:用 Python 画一棵圣诞树作为背景图 在圣诞树背景图中添加雪落效果及音乐 下面来看一下具体实现. 首先,我们来画一棵圣诞树, ...

最新文章

  1. extjs4:代码实现comboBox选中事件
  2. java环境搭建_记一次阿里云服务器Java相关环境搭建的过程
  3. 嵌入式实时系统程序开发一:按键程序编写
  4. 让僵冷的翅膀飞起来—从实例谈OOP、工厂模式和重构[by Wayfarer]
  5. jQuery中this与$(this)区别
  6. OpenCV imwrite
  7. 阶梯英语培训学校致家长书
  8. NOIP2015 写后感
  9. 时间是把杀猪刀...分享我10年的水深火热:软件测试员!
  10. IE6 的 hover 伪类 bug
  11. Ubuntu 安装 Java EE
  12. Illustrator 教程,如何在 Illustrator 中创建单线徽章?
  13. 在Word文档里如何快速返回目录页-Office学习
  14. 树莓派做旁路网关 及 无法上网解决
  15. PT100恒流源测温电路【一】
  16. GCA matting(2020, trimap)
  17. python iter( )函数
  18. 7月23日09点,上海,PMCamp的产品经理大会
  19. 按键(独立按键、矩阵键盘)——附带程序
  20. 【计算机网络】python——socket编程(TCP/UDP)

热门文章

  1. mysql connections参数_MySQL性能优化之max_connections配置参数浅析
  2. Nativefier 网页转桌面程序 app
  3. CentOS 7安装使用Github
  4. 一次搞懂所有排序算法(二)
  5. 企业dns服务器搭建
  6. java中如何调用自身结构_如何在Java中的自定义异常中设置我自己的消息,可以检索我的getMessage()但是没有使用构造函数,有什么办法吗?...
  7. win10系统英雄联盟老是重新连接服务器,win10lol重新连接无法连接服务器重试该怎么才能解决...
  8. MySQL导出到excle显示不了_mysql导出select语句结果到excel文件遇到问题及解决方法_MySQL...
  9. k8s 下线node正确处理姿势
  10. 细说接口性能优化的11个小技巧