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

相关文章

使用Docker构建Python Flask程序的详细教程

《使用Docker构建PythonFlask程序的详细教程》在当今的软件开发领域,容器化技术正变得越来越流行,而Docker无疑是其中的佼佼者,本文我们就来聊聊如何使用Docker构建一个简单的Py... 目录引言一、准备工作二、创建 Flask 应用程序三、创建 dockerfile四、构建 Docker

java向微信服务号发送消息的完整步骤实例

《java向微信服务号发送消息的完整步骤实例》:本文主要介绍java向微信服务号发送消息的相关资料,包括申请测试号获取appID/appsecret、关注公众号获取openID、配置消息模板及代码... 目录步骤1. 申请测试系统2. 公众号账号信息3. 关注测试号二维码4. 消息模板接口5. Java测试

MySQL数据库的内嵌函数和联合查询实例代码

《MySQL数据库的内嵌函数和联合查询实例代码》联合查询是一种将多个查询结果组合在一起的方法,通常使用UNION、UNIONALL、INTERSECT和EXCEPT关键字,下面:本文主要介绍MyS... 目录一.数据库的内嵌函数1.1聚合函数COUNT([DISTINCT] expr)SUM([DISTIN

深度解析Spring AOP @Aspect 原理、实战与最佳实践教程

《深度解析SpringAOP@Aspect原理、实战与最佳实践教程》文章系统讲解了SpringAOP核心概念、实现方式及原理,涵盖横切关注点分离、代理机制(JDK/CGLIB)、切入点类型、性能... 目录1. @ASPect 核心概念1.1 AOP 编程范式1.2 @Aspect 关键特性2. 完整代码实

Java Web实现类似Excel表格锁定功能实战教程

《JavaWeb实现类似Excel表格锁定功能实战教程》本文将详细介绍通过创建特定div元素并利用CSS布局和JavaScript事件监听来实现类似Excel的锁定行和列效果的方法,感兴趣的朋友跟随... 目录1. 模拟Excel表格锁定功能2. 创建3个div元素实现表格锁定2.1 div元素布局设计2.

SpringBoot连接Redis集群教程

《SpringBoot连接Redis集群教程》:本文主要介绍SpringBoot连接Redis集群教程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. 依赖2. 修改配置文件3. 创建RedisClusterConfig4. 测试总结1. 依赖 <de

Python实例题之pygame开发打飞机游戏实例代码

《Python实例题之pygame开发打飞机游戏实例代码》对于python的学习者,能够写出一个飞机大战的程序代码,是不是感觉到非常的开心,:本文主要介绍Python实例题之pygame开发打飞机... 目录题目pygame-aircraft-game使用 Pygame 开发的打飞机游戏脚本代码解释初始化部

Nexus安装和启动的实现教程

《Nexus安装和启动的实现教程》:本文主要介绍Nexus安装和启动的实现教程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、Nexus下载二、Nexus安装和启动三、关闭Nexus总结一、Nexus下载官方下载链接:DownloadWindows系统根

CnPlugin是PL/SQL Developer工具插件使用教程

《CnPlugin是PL/SQLDeveloper工具插件使用教程》:本文主要介绍CnPlugin是PL/SQLDeveloper工具插件使用教程,具有很好的参考价值,希望对大家有所帮助,如有错... 目录PL/SQL Developer工具插件使用安装拷贝文件配置总结PL/SQL Developer工具插

Spring组件实例化扩展点之InstantiationAwareBeanPostProcessor使用场景解析

《Spring组件实例化扩展点之InstantiationAwareBeanPostProcessor使用场景解析》InstantiationAwareBeanPostProcessor是Spring... 目录一、什么是InstantiationAwareBeanPostProcessor?二、核心方法解