用Python和Pygame创造粉色粒子爱心:3D渲染的艺术

news2025/4/10 9:06:04

引言

在计算机图形学中,3D效果的2D渲染是一个迷人的领域。今天,我将分享一个使用Python和Pygame库创建的粉色粒子爱心效果。这个项目不仅视觉效果惊艳,而且代码简洁易懂,非常适合图形编程初学者学习3D渲染的基础概念。

项目概述

这个程序创建了一个由5000个粉色粒子组成的3D爱心,在黑色背景中优雅旋转。粒子会根据其深度改变大小和亮度,创造出真实的3D透视效果。

技术实现

1. 初始化设置

import pygame
import math
import random
from pygame.locals import *

# 初始化pygame
pygame.init()

# 设置窗口
WIDTH, HEIGHT = 550, 400
screen = pygame.display.set_mode((WIDTH, HEIGHT))
pygame.display.set_caption("粉色花生米")

# 颜色定义
BLACK = (0, 0, 0)
PINK = (255, 182, 193)  # 粉红色
LIGHT_PINK = (255, 209, 220)  # 浅粉色

2. 粒子类设计

粒子类是项目的核心,负责每个粒子的3D位置、颜色和渲染:

class Particle:
    def __init__(self):
        # 使用球坐标生成爱心形状的点
        theta = random.uniform(0, math.pi)
        phi = random.uniform(0, 2 * math.pi)
        
        # 爱心形状的球坐标转换
        r = self.heart_shape(theta, phi)
        
        # 转换为3D笛卡尔坐标
        self.x = r * math.sin(theta) * math.cos(phi)
        self.y = r * math.sin(theta) * math.sin(phi)
        self.z = r * math.cos(theta)
        
        # 添加随机扰动使粒子分布更自然
        self.x += random.uniform(-0.3, 0.3)
        self.y += random.uniform(-0.3, 0.3)
        self.z += random.uniform(-0.3, 0.3)
        
        # 粒子属性
        self.base_color = random.choice([PINK, LIGHT_PINK])
        self.base_size = random.uniform(0.5, 1.5)
        self.angle_x = 0
        self.angle_y = 0
        self.angle_z = 0

3. 爱心形状算法

爱心形状是通过球坐标转换实现的数学魔法:

def heart_shape(self, theta, phi):
    """将球坐标转换为爱心形状"""
    t = theta * 2  # 映射到0-2π
    heart_factor = (13*math.cos(t) - 5*math.cos(2*t) - 2*math.cos(3*t) - math.cos(4*t)) / 13
    
    # 转换为球体形状
    r = 10 * (0.8 + 0.2 * heart_factor)
    return r

这个公式基于心形线的极坐标方程,经过调整后适合在3D空间中使用。

4. 3D旋转与投影

粒子在3D空间中的旋转和2D投影是创造3D效果的关键:

def update(self):
    # 旋转角度增量
    self.angle_x += 0.002
    self.angle_y += 0.003
    self.angle_z += 0.001
    
    # 3D旋转 - 绕x、y、z轴旋转
    y_rot = self.y * math.cos(self.angle_x) - self.z * math.sin(self.angle_x)
    z_rot = self.y * math.sin(self.angle_x) + self.z * math.cos(self.angle_x)
    
    x_rot = self.x * math.cos(self.angle_y) + z_rot * math.sin(self.angle_y)
    z_rot = -self.x * math.sin(self.angle_y) + z_rot * math.cos(self.angle_y)
    
    x_final = x_rot * math.cos(self.angle_z) - y_rot * math.sin(self.angle_z)
    y_final = x_rot * math.sin(self.angle_z) + y_rot * math.cos(self.angle_z)
    
    # 透视投影
    scale = 15
    distance = 10
    
    # 计算2D坐标
    x_proj = WIDTH//2 + int(x_final * scale)
    y_proj = HEIGHT//2 - int(y_final * scale)
    
    # 根据深度调整大小和颜色
    depth_factor = (z_rot + distance) / (2 * distance)
    self.curr_size = max(1, int(self.base_size * depth_factor))
    
    color_factor = min(1.0, max(0.4, depth_factor * 1.3))
    r = min(255, max(0, int(self.base_color[0] * color_factor)))
    g = min(255, max(0, int(self.base_color[1] * color_factor)))
    b = min(255, max(0, int(self.base_color[2] * color_factor)))
    self.curr_color = (r, g, b)
    
    return x_proj, y_proj

5. 主循环与渲染

# 创建5000个粒子
particles = [Particle() for _ in range(5000)]

# 主循环
clock = pygame.time.Clock()
running = True

while running:
    for event in pygame.event.get():
        if event.type == QUIT:
            running = False
    
    # 清屏并添加淡出效果
    screen.fill(BLACK)
    fade_surface = pygame.Surface((WIDTH, HEIGHT), pygame.SRCALPHA)
    fade_surface.fill((0, 0, 0, 15))  # 淡出拖尾效果
    screen.blit(fade_surface, (0, 0))
    
    # 绘制所有粒子
    for particle in particles:
        particle.draw(screen)
    
    # 添加文字
    font = pygame.font.SysFont('微软雅黑', 30)
    text = font.render("particles", True, (255, 255, 255))
    screen.blit(text, (WIDTH//2 - text.get_width()//2, 30))
    
    pygame.display.flip()
    clock.tick(60)

pygame.quit()

效果特点

  1. 3D透视:粒子根据深度改变大小和亮度,远处的粒子更小更暗

  2. 平滑动画:三轴不同速度的旋转创造出复杂的运动轨迹

  3. 淡出拖尾:通过半透明覆盖层实现粒子轨迹的淡出效果

  4. 自然分布:随机扰动使粒子分布更加自然,避免机械感

扩展思路

这个基础项目可以进一步扩展:

  1. 交互功能:添加鼠标交互,让爱心跟随鼠标或响应点击

  2. 颜色渐变:实现粒子颜色的动态变化

  3. 粒子系统:添加发射器,创建粒子流动效果

  4. 多爱心组合:渲染多个不同大小和旋转速度的爱心

结语

这个粉色粒子爱心项目展示了如何使用简单的数学原理和基础的图形编程技术创造出令人惊艳的视觉效果。通过调整参数,你可以创建出各种不同的3D形状和动画效果。希望这个项目能激发你对计算机图形学的兴趣!

完整代码已在文章开头提供,复制到Python环境中即可运行(需安装pygame库)。尝试修改参数,创造属于你自己的粒子艺术吧!

小提示:运行代码前请确保已安装pygame库,可以通过pip install pygame安装。

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

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

相关文章

汽车 HMI 设计的发展趋势与设计要点

一、汽车HMI设计的发展历程与现状 汽车人机交互界面(HMI)设计经历了从简单到复杂、从单一到多元的演变过程。2012年以前,汽车HMI主要依赖物理按键进行操作,交互方式较为单一。随着特斯拉Model S的推出,触控屏逐渐成为…

《AI大模型应知应会100篇》第56篇:LangChain快速入门与应用示例

第56篇:LangChain快速入门与应用示例 前言 最近最火的肯定非Manus和OpenManus莫属,因为与传统AI工具仅提供信息不同,Manus能完成端到端的任务闭环。例如用户发送“筛选本月抖音爆款视频”,它会自动完成: 爬取平台数据…

Java 大视界 -- Java 大数据在智能农业无人机植保作业路径规划与药效评估中的应用(165)

💖亲爱的朋友们,热烈欢迎来到 青云交的博客!能与诸位在此相逢,我倍感荣幸。在这飞速更迭的时代,我们都渴望一方心灵净土,而 我的博客 正是这样温暖的所在。这里为你呈上趣味与实用兼具的知识,也…

哈希表系列一>两数之和

目录 题目:方法:暴力代码:优化后代码: 题目: 链接: link 方法: 暴力代码: public int[] twoSum(int[] nums, int target) {解法一:暴力解法:int n nums.length;for(int…

CAD插件实现:自动递增编号(前缀、后缀、位数等)——CADc#实现

cad中大量输入一定格式的递增编号时,可用插件实现,效果如下: ①本插件可指定数字位数、起始号码、加前缀、后缀、文字颜色等(字体样式和文字所在图层为cad当前图层和当前字体样式)。 ②插件采用Jig方式,即…

C语言--回文字符串

输入:字符串,判断是否是回文字符串,例如abcba输出Yes 输出:是否 代码 思路:使用两个指针分别指向头和尾,依次对比第一个元素和最后一个元素,第二个和倒数第二个元素,如果遇到不相同…

Coco-AI 支持嵌入,让你的网站拥有 AI 搜索力

在之前的实践中,我们已经成功地把 Hexo、Hugo 等静态博客和 Coco-AI 检索系统打通了:只要完成向量化索引,就可以通过客户端问答界面实现基于内容的智能检索。 这一层已经很好用了,但总觉得少了点什么—— 比如用户还得专门打开一…

TRDI 公司的RiverPro 和 RioPro ADCP 用户指南

TRDI 公司 RiverPro 和 RioPro ADCP 用户指南 简介第一章 - 概述第二章 - 安装第三章 - 采集数据第四章 - 维护第五章 - 测试RIVERPRO/RIOPRO第六章 - 故障排除第七章 - 将系统返回TRDI进行维修第八章 - 规格第九章 - 命令第十章 - 输出数据格式附录A-合规通知首次完整翻译《Ri…

OpenCV 图形API(11)对图像进行掩码操作的函数mask()

操作系统:ubuntu22.04 OpenCV版本:OpenCV4.9 IDE:Visual Studio Code 编程语言:C11 描述 对矩阵应用掩码。 该函数mask设置来自给定矩阵的值,如果掩码矩阵中对应的像素值设为true,否则将矩阵的值设为0。 支持的源矩阵…

使用C#写的一个Kafka的使用工具

由于offset不支持通过界面推送数据,所以我写了一个kafka的连接工具,能够直接从界面推送数据,方便使用。由于使用的是C#写的,所以比offset要流畅的多。 1、数据源连接 2、获取集群的topic 3、点击获取数据能够获取最新的100条数…

【通知】STM32MP157驱动开发课程全新升级!零基础入门嵌入式Linux驱动,掌握底层开发核心技能!

在嵌入式Linux系统开发中,驱动程序开发是一项关键技术,它作为硬件与软件之间的桥梁,实现了操作系统对硬件设备的控制。相较于嵌入式Linux应用开发,驱动开发由于涉及底层硬件且抽象程度较高,往往让初学者感到难度较大。…

飞浆PaddlePaddle 猫狗数据大战

猫狗数据大战 1 数据集的准备以及处理操作1.1 数据集1.2 文件解压操作(python) 1.3 数据的分类1.4 创建训练集和测试集 2 网络构建CNN版本--DeepID 人脸识别网络结构DeepID 与 CNN 网络结构的差异 3 深度学习模型训练和推理的核心设置4 制图5 训练6 预测…

使用高德api实现天气查询

创建应用获取 Key 天气查询-基础 API 文档-开发指南-Web服务 API | 高德地图API 代码编写 <!DOCTYPE html> <html lang"zh-CN"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-wid…

Could not find artifact com.microsoft.sqlserver:sqljdbc4:jar:4.0 in central

具体错误 [ERROR] Failed to execute goal on project datalink-resource: Could not resolve dependencies for project com.leon.datalink:datalink-resource:jar:1.0.0: Could not find artifact com.microsoft.sqlserver:sqljdbc4:jar:4.0 in central (https://repo.maven…

Express学习笔记(三)——使用 Express 写接口

目录 1. 创建基本的服务器 2. 创建 API 路由模块 3. 编写 GET 接口 4. 编写 POST 接口 5. CORS 跨域资源共享 5.1 接口的跨域问题 5.2 使用 cors 中间件解决跨域问题 5.3 什么是 CORS 5.4 CORS 的注意事项 5.5 CORS 响应头部 - Access-Control-Allow-Origin 5.6 COR…

【HarmonyOS Next之旅】DevEco Studio使用指南(十)

目录 1 -> Optimize Imports功能 2 -> 父/子类快速跳转 3 -> 查看接口/类的层次结构 4 -> 代码自动补全 1 -> Optimize Imports功能 使用编辑器提供的Optimize Imports&#xff0c;可以快速清除未使用的import&#xff0c;并根据设置的规则对import进行合并…

java并发编程-并发容器

并发容器 CopyOnWriteArrayListCopyOnWriteArraySetConcurrentHashMapConcurrentSkipListMap迭代器的fail-fast与fail-safe机制应用场景 CopyOnWriteArrayList 线程不安全容器&#xff1a;ArrayList代替Vector、synchronizedList适用于读多写少的场景&#xff0c;对读操作不加…

PPT助手:一款集计时、远程控制与多屏切换于一身的PPT辅助工具

PPT助手&#xff1a;一款集计时、远程控制与多屏切换于一身的PPT辅助工具 &#x1f4dd;&#x1f3a4; 在现代化的演讲和演示中&#xff0c;如何高效地控制PPT进程、保证展示的流畅性与精准性&#xff0c;成为了每个演讲者必须面对的挑战。无论是商务汇报、学术演讲&#xff0…

大模型应用初学指南

随着人工智能技术的快速发展&#xff0c;检索增强生成&#xff08;RAG&#xff09;作为一种结合检索与生成的创新技术&#xff0c;正在重新定义信息检索的方式&#xff0c;RAG 的核心原理及其在实际应用中的挑战与解决方案&#xff0c;通用大模型在知识局限性、幻觉问题和数据安…

如何通过管理系统提升团队协作效率

在现代企业管理中&#xff0c;团队协作效率的高低直接关系到企业的竞争力和运营效率。随着信息技术的不断发展&#xff0c;管理系统作为提升团队协作效率的重要工具&#xff0c;逐渐受到企业的重视。本文将深入探讨如何通过管理系统提升团队协作效率&#xff0c;为企业提供实用…