Python实现动态银河系:模拟旋转的银河动画

news2025/1/23 6:02:06

文章目录

    • 引言
    • 准备工作
      • 前置条件
    • 代码实现与解析
      • 导入必要的库
      • 初始化Pygame
      • 定义星系类
      • 主循环
    • 完整代码

在这里插入图片描述

引言

银河系的旋转动画是一个迷人且富有挑战性的项目。通过模拟星系的旋转,我们可以更好地理解天文学现象,并创造出视觉上令人惊叹的效果。在这篇博客中,我们将使用Python创建一个动态旋转的银河系动画。通过利用Pygame库,我们可以实现这个美丽的视觉效果。

准备工作

前置条件

在开始之前,你需要确保你的系统已经安装了Pygame库。如果你还没有安装它,可以使用以下命令进行安装:

pip install pygame

Pygame是一个跨平台的Python模块,用于编写视频游戏。它包括计算机图形和声音库,使得游戏开发更加简单。

代码实现与解析

导入必要的库

我们首先需要导入Pygame库和其他必要的模块:

import pygame
import random
import math

初始化Pygame

我们需要初始化Pygame并设置屏幕的基本参数:

pygame.init()
screen = pygame.display.set_mode((800, 800))
pygame.display.set_caption("旋转的银河动画")
clock = pygame.time.Clock()

定义星系类

我们创建一个Galaxy类来定义星系的属性和行为:

class Galaxy:
    def __init__(self, num_stars):
        self.num_stars = num_stars
        self.stars = []
        self.center = (400, 400)
        self.generate_stars()

    def generate_stars(self):
        for _ in range(self.num_stars):
            angle = random.uniform(0, 2 * math.pi)
            distance = random.uniform(50, 350)
            x = self.center[0] + distance * math.cos(angle)
            y = self.center[1] + distance * math.sin(angle)
            speed = random.uniform(0.001, 0.01)
            self.stars.append([x, y, angle, distance, speed])

    def update(self):
        for star in self.stars:
            star[2] += star[4]
            star[0] = self.center[0] + star[3] * math.cos(star[2])
            star[1] = self.center[1] + star[3] * math.sin(star[2])

    def draw(self, screen):
        for star in self.stars:
            pygame.draw.circle(screen, (255, 255, 255), (int(star[0]), int(star[1])), 2)

主循环

我们在主循环中更新星系的旋转状态并绘制:

galaxy = Galaxy(500)

running = True
while running:
    for event in pygame.event.get():
        if event.type == pygame.QUIT:
            running = False

    screen.fill((0, 0, 0))
    
    galaxy.update()
    galaxy.draw(screen)

    pygame.display.flip()
    clock.tick(60)

pygame.quit()

完整代码

import pygame
import random
import math

# 初始化Pygame
pygame.init()
screen = pygame.display.set_mode((800, 800))
pygame.display.set_caption("旋转的银河动画")
clock = pygame.time.Clock()

# 星系类定义
class Galaxy:
    def __init__(self, num_stars):
        self.num_stars = num_stars
        self.stars = []
        self.center = (400, 400)
        self.generate_stars()

    def generate_stars(self):
        for _ in range(self.num_stars):
            angle = random.uniform(0, 2 * math.pi)
            distance = random.uniform(50, 350)
            x = self.center[0] + distance * math.cos(angle)
            y = self.center[1] + distance * math.sin(angle)
            speed = random.uniform(0.001, 0.01)
            self.stars.append([x, y, angle, distance, speed])

    def update(self):
        for star in self.stars:
            star[2] += star[4]
            star[0] = self.center[0] + star[3] * math.cos(star[2])
            star[1] = self.center[1] + star[3] * math.sin(star[2])

    def draw(self, screen):
        for star in self.stars:
            pygame.draw.circle(screen, (255, 255, 255), (int(star[0]), int(star[1])), 2)

# 主循环
galaxy = Galaxy(500)

running = True
while running:
    for event in pygame.event.get():
        if event.type == pygame.QUIT:
            running = False

    screen.fill((0, 0, 0))
    
    galaxy.update()
    galaxy.draw(screen)

    pygame.display.flip()
    clock.tick(60)

pygame.quit()

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1909647.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

计算机网络 - 万字长文

计算机网络 二、计算机网络2.1 七层模型表格2.2 通俗讲解七层模型2.3 TCP与UDP对比2.4 TCP 三次握手过程==为什么握手是三次,而不是两次或者四次?====三次握手可以携带数据吗?====TCP三次握手失败,服务端会如何处理?====什么是半连接队列?全连接====ISN(Initial Sequence…

昇思MindSpore学习入门-CELL与参数一

Cell作为神经网络构造的基础单元,与神经网络层(Layer)的概念相对应,对Tensor计算操作的抽象封装,能够更准确清晰地对神经网络结构进行表示。除了基础的Tensor计算流程定义外,神经网络层还包含了参数管理、状态管理等功能。而参数(…

【Python】已解决:(最新版selenium框架元素定位报错)NameError: name ‘By’ is not defined

文章目录 一、分析问题背景二、可能出错的原因三、错误代码示例四、正确代码示例五、注意事项 已解决:(最新版selenium框架元素定位报错)NameError: name ‘By’ is not defined 一、分析问题背景 在使用Selenium进行Web自动化测试或爬虫开…

R包:‘patchwork合并多个R图的包‘

介绍 patchwork是基于gglot2的拼图包,它使得基于ggplot2的图形更容易拼接在同一个图层。 安装 因为作者仅仅在GitHub发布了patchwork,因此无法使用install.packages("patchwork")从CRAN处获取。为了获取该包,首先应该安装devtoo…

十进制与十六进制,和二进制的相互转变

十六进制与十进制 十六进制(Hexadecimal)是一种进位制,基数为16,常用于计算机科学和电子工程中。十六进制使用16个符号来表示数值:0-9表示0到9,A-F表示10到15。十六进制的每一位可以表示4位二进制数&#…

万界星空科技MES:磷酸铁锂正极新材料生产管理系统

磷酸铁锂MES通过对生产现场的数据进行实时采集、处理和监控,实现对生产过程的优化和控制。它可以实时监控生产设备的运行状态、物料的使用情况、产品的生产进度等信息,并根据这些信息对生产过程进行调整和优化。例如,当发现某个生产设备的故障…

电脑桌面日历记事本怎么弄 好用的桌面日历记事本

在这个数字化的时代,电脑已成为我们日常生活中不可或缺的伙伴。我常常在电脑上记录各种事项,以便随时查看和提醒自己。而我最钟爱的记事方式,莫过于使用桌面日历记事本。 想象一下,你的电脑桌面上有一个直观的日历,每…

【Elasticsearch】开源搜索技术的演进与选择:Elasticsearch 与 OpenSearch

开源搜索技术的演进与选择:Elasticsearch 与 OpenSearch 1.历史发展2.OpenSearch 与 Elasticsearch 相同点3.OpenSearch 与 Elasticsearch 不同点3.1 版本大不同3.2 许可证不同3.3 社区不同3.4 功能不同3.5 安全性不同3.6 性能不同3.7 价格不同3.8 两者可相互导入 4…

【大模型】提示工程基础学习

目录 1. 零样本提示2. 少样本提示3. 链式思考提示(CoT)4. 自我一致性5. 生成知识提示6. 链式提示7. 思维树(ToT)8. 检索增强生成(RAG)9. active prompt10. 自我反思(reflexion)11. 多…

儿童网络守护计划:如何为孩子营造一个纯净的在线空间?

青少年不想被监视,但他们需要受到保护,免受互联网危险。我们告诉您如何与您的孩子建立信任,同时了解他们在网上面临的挑战。 对于今天的孩子来说,将离线和在线朋友分开是不可能的。青少年在任何时候都与一切事物和每个人联系在一起…

2024年道路运输企业主要负责人证考试题库及道路运输企业主要负责人试题解析

题库来源:安全生产模拟考试一点通公众号小程序 2024年道路运输企业主要负责人证考试题库及道路运输企业主要负责人试题解析是安全生产模拟考试一点通结合(安监局)特种作业人员操作证考试大纲和(质检局)特种设备作业人…

MFC引用C#生成的dll,将dll放置到非exe程序目录,如何操作?

🏆本文收录于「Bug调优」专栏,主要记录项目实战过程中的Bug之前因后果及提供真实有效的解决方案,希望能够助你一臂之力,帮你早日登顶实现财富自由🚀;同时,欢迎大家关注&&收藏&&…

【Linux进阶】vim的用法

1.什么是vi/vim? 简单来说,vi是老式的文本编辑器,不过功能已经很齐全了,但是还是有可以进步的地方。vim则可以说是程序开发者的一项很好用的工具,就连 vim的官方网站( http://www.vim.org)自己也说vim是一…

《无所不能的JavaScript · prototype 原型链》

📢 大家好,我是 【战神刘玉栋】,有10多年的研发经验,致力于前后端技术栈的知识沉淀和传播。 💗 🌻 近期刚转战 CSDN,会严格把控文章质量,绝不滥竽充数,欢迎多多交流。&am…

掌握Midjourney:一份全面的使用教程

Midjourney 它是一种通过人工智能生成图片的人工智能绘画工具,如何使用Midjourney?很简单,只要在对话框中输入imagine 命令,添加您需要的图像描述或关键字,并在发送后生成相应的艺术图片。除了其强大的生图功能外&…

STM32CubeMX如何配置生成项目以及安装包

目录 一、STM32CubeMX介绍 二、用STM32CubeMX生成项目 1.创建项目 2.定义引脚 3.配置时钟 4.保存项目 5.生成项目 6.打开项目 一、STM32CubeMX介绍 STM32CubeMX是STM32Cube工具家族中的一员,专门为STM32微控制器的开发提供便利。它是一款图形化工具&#xf…

古代VS现代,太阳黑子的影响有什么变化?

公元前28年,我国汉朝人在人类历史上第一次记载下了“太阳黑子”。在《汉书五行志》里是这样记载:“汉成帝河平元年三月乙未,日出黄,有黑气,大如钱,居日中央”。在2052年前,人类对于太阳黑子的认…

基于考研题库小程序V2.0实现倒计时功能板块和超时判错功能

V2.0 需求沟通 需求分析 计时模块 3.1.1、功能描述←计时模块用于做题过程中对每一题的作答进行30秒倒计时,超时直接判错,同时将总用时显示在界面上;记录每次做题的总用时。 3.1.2、接口描述←与判定模块的接口为超时判定,若单题用时超过 …

【BUG】已解决:JsonMappingException

已解决:JsonMappingException 欢迎来到英杰社区https://bbs.csdn.net/topics/617804998 概述: 没有getter方法的实体的序列化,并解决Jackson引发的JsonMappingException异常。 默认情况下,Jackson 2只会处理公有字段或具有公有get…

镭速助力全球高速传输,实现点对点高效传输打破时差壁垒!

在当今全球化的背景下,跨国界的文件协作已成为许多跨国企业日常工作的一部分。但是,时差和网络不稳定等因素常常影响团队间的有效交流与合作。特别是在大文件传输环节,传统的在线传输方法在接收方离线或网络条件不佳时显得力不从心&#xff0…