pygame教程实例(二)模拟三体

2023-11-10 07:40

本文主要是介绍pygame教程实例(二)模拟三体,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

上一篇:pygame教程实例(一)小球弹跳
下一篇:pygame教程实例(三)游戏事件


本教程使用python3
我的另一篇文章pygame春节十二响

阅读本文需要一些简单的物理知识
上一篇我们写了一个小球在重力的作用下反复弹跳,现在我们来实现模拟三体运动。
三体运动是指三个质量相差不大的天体相互作用下的运动。


一、定义一些常量和初始化

from sys import exit
import pygame, math
from pygame.color import *G     = 900  # 重力常量
FPS   = 50   # 帧率
exact = 50   # 每帧计算几次,次数越多越精确,它是动态变化的pygame.init()  # 初始化pygame
screen = pygame.display.set_mode((640, 480), pygame.DOUBLEBUF, 32)
pygame.display.set_caption("模拟三体")
clock = pygame.time.Clock()
font = pygame.font.SysFont("Arial", 16)

二、定义星球类

class Star():x , y  = 0, 0  # 坐标vx, vy = 0, 0  # x,y方向上的速度ax, ay = 0, 0  # x,y方向上的加速度m = 0  # 质量r = 10 # 半径def __init__(self, x, y, vx, vy, m):self.x = xself.y = yself.vx = vxself.vy = vyself.m = mdef set_a(self, other_star):'''计算star与other_star之间的重力加速度'''d_2 = (self.x - other_star.x) ** 2 + (self.y - other_star.y) ** 2_x = [-1, 1][self.x < other_star.x]_y = [-1, 1][self.y < other_star.y]if d_2 != 0:a = G * self.m * other_star.m / d_2else:a = 0if self.x != other_star.x:ax_ = math.sqrt(a ** 2 / (((self.y - other_star.y) / (self.x - other_star.x)) ** 2 + 1))self.ax += ax_ * _xself.ay += math.sqrt(a ** 2 - ax_ ** 2) * _yelse:self.ay += a * _ydef run(self, time):'''计算time时间后的位置:param time:时间,秒 :return: '''self.ax /= self.mself.ay /= self.mself.vx += self.ax * timeself.vy += self.ay * timeself.x += self.vx * timeself.y += self.vy * time

三、设置三个星球

star_list = []
dd = 0.00001
star_list.append(Star(200, 300,-30,-math.sqrt(3)*30, 1000))
star_list.append(Star(400, 300,-30, math.sqrt(3)*30, 1000))
star_list.append(Star(300, 300-math.sqrt(3)*100+dd, 60, 0, 1000))

四、主循环

# 计算引力加速度
def set_a(star_list):for i, star in enumerate(star_list):star.ax, star.ay = 0, 0for j, other_star in enumerate(star_list):if i != j:star.set_a(other_star)# 游戏主循环
while True:for event in pygame.event.get():if event.type == pygame.QUIT:# 接收到退出时间后退出程序exit()for i in range(exact):set_a(star_list)for star in star_list:star.run(1 / FPS / exact)# 将背景图画上去screen.fill((0, 0, 0))max_v = 0for star in star_list:max_v = max(max_v, math.sqrt(star.vx**2+star.vy**2))pygame.draw.circle(screen, (255, 0, 0), (int(star.x), int(star.y)), star.r)exact = min(300,max(30,int(max_v)))*5screen.blit(font.render("fps: " + str(clock.get_fps()), 1, THECOLORS["white"]), (0,0))screen.blit(font.render("exact: " + str(exact), 1, THECOLORS["white"]), (0,15))# 刷新画面pygame.display.update()time_passed = clock.tick(FPS)

五、最终效果图

稍微加快了一点
模拟三体
上一篇:pygame教程实例(一)小球弹跳
下一篇:pygame教程实例(三)游戏事件

这篇关于pygame教程实例(二)模拟三体的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/381288

相关文章

springboot使用Scheduling实现动态增删启停定时任务教程

《springboot使用Scheduling实现动态增删启停定时任务教程》:本文主要介绍springboot使用Scheduling实现动态增删启停定时任务教程,具有很好的参考价值,希望对大家有... 目录1、配置定时任务需要的线程池2、创建ScheduledFuture的包装类3、注册定时任务,增加、删

如何为Yarn配置国内源的详细教程

《如何为Yarn配置国内源的详细教程》在使用Yarn进行项目开发时,由于网络原因,直接使用官方源可能会导致下载速度慢或连接失败,配置国内源可以显著提高包的下载速度和稳定性,本文将详细介绍如何为Yarn... 目录一、查询当前使用的镜像源二、设置国内源1. 设置为淘宝镜像源2. 设置为其他国内源三、还原为官方

Maven的使用和配置国内源的保姆级教程

《Maven的使用和配置国内源的保姆级教程》Maven是⼀个项目管理工具,基于POM(ProjectObjectModel,项目对象模型)的概念,Maven可以通过一小段描述信息来管理项目的构建,报告... 目录1. 什么是Maven?2.创建⼀个Maven项目3.Maven 核心功能4.使用Maven H

Vue3组件中getCurrentInstance()获取App实例,但是返回null的解决方案

《Vue3组件中getCurrentInstance()获取App实例,但是返回null的解决方案》:本文主要介绍Vue3组件中getCurrentInstance()获取App实例,但是返回nu... 目录vue3组件中getCurrentInstajavascriptnce()获取App实例,但是返回n

IDEA自动生成注释模板的配置教程

《IDEA自动生成注释模板的配置教程》本文介绍了如何在IntelliJIDEA中配置类和方法的注释模板,包括自动生成项目名称、包名、日期和时间等内容,以及如何定制参数和返回值的注释格式,需要的朋友可以... 目录项目场景配置方法类注释模板定义类开头的注释步骤类注释效果方法注释模板定义方法开头的注释步骤方法注

SQL表间关联查询实例详解

《SQL表间关联查询实例详解》本文主要讲解SQL语句中常用的表间关联查询方式,包括:左连接(leftjoin)、右连接(rightjoin)、全连接(fulljoin)、内连接(innerjoin)、... 目录简介样例准备左外连接右外连接全外连接内连接交叉连接自然连接简介本文主要讲解SQL语句中常用的表

Python虚拟环境终极(含PyCharm的使用教程)

《Python虚拟环境终极(含PyCharm的使用教程)》:本文主要介绍Python虚拟环境终极(含PyCharm的使用教程),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录一、为什么需要虚拟环境?二、虚拟环境创建方式对比三、命令行创建虚拟环境(venv)3.1 基础命令3

使用Node.js制作图片上传服务的详细教程

《使用Node.js制作图片上传服务的详细教程》在现代Web应用开发中,图片上传是一项常见且重要的功能,借助Node.js强大的生态系统,我们可以轻松搭建高效的图片上传服务,本文将深入探讨如何使用No... 目录准备工作搭建 Express 服务器配置 multer 进行图片上传处理图片上传请求完整代码示例

python连接本地SQL server详细图文教程

《python连接本地SQLserver详细图文教程》在数据分析领域,经常需要从数据库中获取数据进行分析和处理,下面:本文主要介绍python连接本地SQLserver的相关资料,文中通过代码... 目录一.设置本地账号1.新建用户2.开启双重验证3,开启TCP/IP本地服务二js.python连接实例1.

Python 安装和配置flask, flask_cors的图文教程

《Python安装和配置flask,flask_cors的图文教程》:本文主要介绍Python安装和配置flask,flask_cors的图文教程,本文通过图文并茂的形式给大家介绍的非常详细,... 目录一.python安装:二,配置环境变量,三:检查Python安装和环境变量,四:安装flask和flas