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

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

实现

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

import sys

import math

import pygame

from pygame.locals import *1

2

3

4

接着定义一些常量(如:颜色、宽高等)及创建窗口,代码如下所示:

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, 600

screen = 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 = 0

roll_3 = roll_4 = roll_5 = roll_6 = roll_7 = roll_8 = 0

# 太阳的位置(中心)

position = size[0] // 2, size[1] // 21

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

我们先在窗口中画一个太阳,代码如下:

pygame.draw.circle(screen, YELLOW, position, 60, 0)1

看一下效果:

接着画一个地球,让其绕着太阳旋转,代码如下:

# 画地球

roll_e += 0.01 # 假设地球每帧公转 0.01 pi

pos_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)1

2

3

4

5

6

7

8

9

10

11

看一下效果:

我们再接着画月球,代码如下:

# 画月球

roll_m += 0.1

pos_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)1

2

3

4

5

6

7

8

9

10

11

看一下效果:

其他几个星球的实现也类似,代码如下:

# 其他几个行星

roll_3 += 0.03

pos_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.04

pos_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.05

pos_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.06

pos_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.07

pos_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.08

pos_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)1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

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

是不是有内味了。

总结

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

源码在公众号 Python小二 后台回复 200812 获取。

本文非首发于个人号

文章来源: blog.csdn.net,作者:Python小二,版权归原作者所有,如需转载,请联系作者。

原文链接:blog.csdn.net/ityard/article/details/113793230

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

  1. python 概率分布模型_使用python的概率模型进行公司估值

    python 概率分布模型 Note from Towards Data Science's editors: While we allow independent authors to publis ...

  2. python 时间序列预测_使用Python进行动手时间序列预测

    python 时间序列预测 Time series analysis is the endeavor of extracting meaningful summary and statistical ...

  3. 用python画太阳系_用 Python 动态模拟太阳系运转

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

  4. python模拟行星运动_使用 Python 来简单的动态模拟一下太阳系的运转

    前言 本文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理. 以下文章来源于Python技术 ,作者派森酱 提到太阳系,大家可能会想到哥 ...

  5. python绘制太阳系_使用 Python 来简单的动态模拟一下太阳系的运转

    前言 本文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理. 以下文章来源于Python技术 ,作者派森酱 提到太阳系,大家可能会想到哥 ...

  6. python 三维地球_用python生成地球运动的动态模拟动态图

    python作为一门简单易学且应用范围极广的语言有着其他语言无法比拟的优势,通过python可以实现各种各样的功能,例如我们可以利用python matplotlib的绘图库实现各种动态模拟仿真,在科 ...

  7. python笛卡尔_用Python 3来模拟笛卡尔积

    在数学中,两个集合 和 的笛卡尔积,是所有可能的有序对组成的集合,其中有序对的第一个对象是 的成员,第二个对象是 的成员.在集合论中表示为 ,例子如下: . 例如,集合 , ,那么这两个集合的笛卡尔积 ...

  8. python声明数组_在Python中如何声明动态数组

    I want to declare an Array and all items present in the ListBox Should Be deleted irrespective of th ...

  9. python写金字塔_金字塔python开发手册

    python API 基本方法 编写策略过程中所需要使用的基本函数.其中init和handle_bar是必须实现的两个方法,其余是可选择实现的方法. init (必须实现) init(context) ...

最新文章

  1. 每日一皮:美丽的背后都妙不可言...
  2. 007_Redis的Set数据类型
  3. 也谈游戏--魔兽和星际的区别
  4. Shiro集成Web时的url匹配规则
  5. webGL简单例子(klayge)
  6. MySQL 下载与配置教程(免安装版)
  7. maven工程xml文件路径问题
  8. Struts2中的OGNL表达式
  9. 计算机硬件统的构成,计算机硬件统的构成部件.ppt
  10. Tensorflow之 CNN卷积神经网络的MNIST手写数字识别
  11. 基于JAVA+Servlet+JSP+MYSQL的员工报销管理系统
  12. java实现用户分组,根据用户指定的组分组数据
  13. 使用SCCM Toolkit2中的Trace32来查看MDT日志
  14. 你见过哪些操蛋的代码?切勿模仿! 否则后果自负
  15. 网站敏感词过滤的实现(附敏感词库)
  16. 精心挑选的100多种机器学习数据集
  17. Hyperledger Fabric Transaction Proposal过程
  18. JavaEE进阶知识学习-----Java8新特性知识学习-4-1-StreamAPI
  19. 使用wx原生方法扫描获取SN码
  20. Html网页设计-羽毛球网站设计

热门文章

  1. 如何使用 ABAP 报表将 ABAP 服务器上的 SAP UI5 应用下载到本地
  2. SAP Spartacus里的WindowRef对象
  3. 我的工作日常:一个CSS问题引起的小插曲
  4. 一行代码取出HTML页面某个按钮的css属性,比如margin
  5. 关于rxjs里operators filter和map的详细讨论
  6. SAP Cloud Platform mobile service的使用过程
  7. first level cache check - User parameter /UI2/CACHE_DISABLE
  8. My Lead route attach and detach issue
  9. 阮一峰react demo代码研究的学习笔记 - demo2 debug
  10. 在Ubuntu上安装SAP Cloud Connector的一些错误