用 Python 动态模拟太阳系运转

来源:Python 技术「ID: pythonall」

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

太阳以巨大的引力使周边行星、卫星等绕其运转,构成了太阳系,它主要包括太阳、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 简单模拟了太阳系的运转,有兴趣的小伙伴可以自己运行一下代码或对功能做进一步扩展。

(0)

相关推荐

  • 【每周一坑】阿姆斯特朗数

    这是一个很经典的编程练习题: 如果一个正整数等于其各个数字的立方和,则称该数为阿姆斯特朗数(亦称为自恋数.自幂数). 如 407 = 43 + 03 + 73 就是一个阿姆斯特朗数. 写一段代码,输出 ...

  • java学习——103.画同心圆

    接上篇,上篇是将直线画在一块画布上的. 但是,paint()方法其实是每一个组件都包含的方法,故可直接在窗口中画图. 本篇,以同心圆为例,在窗口中直接画同心圆. 此同心圆从窗口的中心位置开始,向外辐射 ...

  • 用pygame开发自己的游戏-1. 基础与入门

    一.前言 pygame是一个用Python写的SDL库.SDL是一个能访问计算机多媒体硬件组件(包括声卡,视频卡,输入组件等)的跨平台库.本系列主要通过pygame做小游戏来学习编程.对于学过基本语法 ...

  • 用Python简单实现模拟太阳系运转

    前言 本文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,如有问题请及时联系我们以作处理. PS:如有需要Python学习资料的小伙伴可以点击下方链接自行获取 Python免费学习资料 ...

  • Aspen Plus Dynamics(一):稳态模拟到动态模拟的转变

    化工装置运行过程的稳定操作对于生产而言是很重要的,进料不可能没有波动,温度也不可能恒定在一个点,这些变化有些是可预知的,有些是突发的.要实现平稳操作,首先,我们在设计装置时需要保留一定的操作余量和空间 ...

  • 一百多个测量演示动画轻松学习测量,动态模拟,一目了然通俗易懂

    内容介绍 对于测量初学者来说,初学测量晦涩难懂,小新整理处理了100多个测量演示动画,总共10个章节,包含控制测量,水准仪经纬仪测量,碎步测量,控制测量,施工放线,演示等.内容简单有趣,通俗易懂,一看 ...

  • 模拟太阳系8大行星运行图:matplotlib实现

    模拟太阳系8大行星运行图:matplotlib实现

  • Python爬虫模拟登陆哔哩哔哩(bilibili)并突破点选验证码功能

    写在前面   今天带给大家一个突破点选验证码的案例,利用爬虫模拟登陆哔哩哔哩,并且把一些采坑的地方给大家强调一下! 一.需求分析   模拟登陆哔哩哔哩   网站链接: https://passport ...

  • 全站仪使用不熟练?120页系统讲解手册 动态模拟演示,快拿走

    全站仪使用不熟练?120页系统讲解手册+动态模拟演示,快拿走 对于测量员来说,对于全站仪再熟悉不过了.它作为既能测角又能测距的仪器,在工程测量中应用的相当广泛,需要熟练的掌握操作方法才能在日常工作中做 ...

  • 爱了!Python 动态图表太太太秀了

    本文转自:法纳斯特,作者:小F 关于动态条形图,小F以前推荐过「Bar Chart Race」这个库.三行代码就能实现动态条形图的绘制. 有些同学在使用的时候,会出现一些错误.一个是加载文件报错,另一 ...

  • 通过模拟温度记忆来动态模拟茶芽中的抗寒性

    Dynamic modeling of cold hardiness in tea buds by imitating past temperature memory 通过模拟温度记忆来动态模拟茶芽中 ...

  • 基于WORKING MODEL的静电感应现象动态模拟演示动画

    图1 为了让学生明白静电感应的基本规律,在理论分析的同时,需要辅助以形象化的演示手段. 这是一个基于WORKING MODEL的静电感应现象动态模拟演示动画,在WORKING MODEL中简单搭建物理 ...