前言

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

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

实现

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

import sys

import math

import pygame

from 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, 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] // 2

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

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

看一下效果:

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

# 画地球

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)

看一下效果:

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

# 画月球

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)

看一下效果:

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

# 其他几个行星

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)

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

是不是有内味了。

总结

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

到此这篇关于如何利用Python动态模拟太阳系运转的文章就介绍到这了,更多相关Python动态模拟太阳系运转内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

python绘制太阳系_如何利用Python动态模拟太阳系运转相关推荐

  1. 怎么用python找论文_如何利用Python绘制学术论文图表方法

    论文中图表形式多样,常用的处理工具有excel.MATLAB以及Python等,excel自处理的方法有两个缺陷: 1.当数据较多时,容易出现excel"翻白眼"的现象: 2.需要 ...

  2. python数据论文_如何利用Python绘制学术论文图表

    论文中图表形式多样,常用的处理工具有excel.MATLAB以及Python等,excel自处理的方法有两个缺陷:1.当数据较多时,容易出现excel"翻白眼"的现象:2.需要使用 ...

  3. python画四角星_如何利用Python|对多角星的绘制

    本文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理 以下文章来源于腾讯云,作者:编程与算法之美. 1 前言 在初步学习python的过 ...

  4. 怎么用python绘制柱状图_如何用python快速简单的制作柱状图?

    柱状图大家都会制作,那么你会用python制作柱状图吗? 我们先来看一下柱状图的定义:柱形图,又被称为长条图.或者柱状统计图,也叫作条图.条状图.棒形图,本质上来说就是一种以长方形的长度为变量的统计图 ...

  5. 利用python进行数据分析_资料 | 利用Python进行数据分析

    下载地址:https://www.yanxishe.com/resourceDetail/1443?from=leiphonecolumn_res0518 以下内容节选自豆瓣: 内容简介 · · · ...

  6. python求加速度_如何利用Python 为自然语言处理加速度

    自去年发布 Python 的指代消解包(coreference resolution package)之后,很多用户开始用它来构建许多应用程序,而这些应用与我们最初的对话应用完全不同. 利用 spaC ...

  7. 用python做头像_如何利用python制作微信好友头像照片墙?

    这个不难,主要用到itchat和pillow这2个库,其中itchat用于获取微信好友头像照片,pillow用于拼接头像生成一个照片墙,下面我简单介绍一下实现过程,代码量不多,也很好理解,实验环境wi ...

  8. python epub 精品_如何利用Python打包HTML页面为epub?

    最近沉迷于将各种博客和官方文档html转化成pdf,结果用手机看还是不太方便,所以想到将html转化成epub格式的电子书,要用os,re,requests,lxm,zipfile,五个库,在这里分享 ...

  9. python绘制直角坐标系_小白学 Python 数据分析(16):Matplotlib(一)坐标系

    人生苦短,我用 Python 前文传送门: 引言 各位同学好,本篇文章,我们来介绍下使用 Matplotlib 时如何建立坐标系. 回想一下以前我们在接受九年义务教育毒打上数学课的时候,应该都画过折线 ...

最新文章

  1. org.apache.ibatis.binding.BindingException: Type interface XXX is not known to the MapperRegistry.
  2. centos7.4 ngixn1.13.10 mysql5.7.21 php7.2.3 源码编译安装之后php无法连接mysql
  3. Spring事务与自定义多线程陷阱
  4. centos7.3安装elasticsearch-head
  5. camel java_与Java EE和Camel的轻量级集成
  6. anaconda下载的python在哪_python包管理器anaconda介绍安装和使用
  7. java 银行系统_JAVA之银行系统1
  8. w讠ndows的中文读音,广西壮族自治区
  9. 罗永浩如果倒过来过,也很励志
  10. VMware虚拟机的创建
  11. 如何写好一份 30 K offer 的简历(建议收藏)
  12. finecms aip.php漏洞,FineCMS最新getshell漏洞通杀FineCMS5.0.8一下版本 | CN-SEC 中文网
  13. 准备入行java怎么才能更快学习
  14. 结婚戒指为什么要带在无名指上
  15. 利用ESP8266+OLED(I2C)打造智能时钟(网络校时+实时天气+天气预报)
  16. 公民实验室:史上危险的手机间谍软件已感染45个国家/地区
  17. 鞍山树人计算机学校宿舍,南开大学校务公报2016年第12期-信息公开.pdf
  18. kali linux 安装驱动安装教程,Kali Linux 安装英伟达显卡过程实录
  19. 快手直播弹幕数据采集
  20. PS(2018)更换启动界面

热门文章

  1. 两个瓶盖换一瓶可乐问题
  2. 第二阶段--团队冲刺--第八天
  3. 获得商品详情API接口
  4. 使用IDEA工具查看Java类层次结构关系图
  5. 存储芯片引脚和时序:SRAM(HY6264A系列)
  6. 关于vuze(毒蛙)linux版本移植的问题
  7. KONG网关和KONGA界面的入门使用,快速上手
  8. 定风波/三月七日——苏轼
  9. 证明残差的平均值等于0,残差以x加权的平均值为0
  10. 7.2 一次产品异常复位引发的质量提升经历