当前位置: 首页 > news >正文

气泡特效的核心在于BubbleEffect类,它继承自Manim的Animation类,通过重写关键方法来实现气泡的上升、变大和透明度变化效果。

核心类结构

BubbleEffect类的基本结构如下:

class BubbleEffect(Animation): """ 彩色气泡特效动画类 继承自Animation类,用于创建彩色气泡上升、变大、透明度变化的效果 """ def __init__( self, bubble_count=25, # 气泡数量 bubble_size_range=(0.1, 0.5), # 气泡大小范围 rise_speed_range=(0.6, 2.2), # 上升速度范围 growth_rate_range=(0.005, 0.015), # 生长速度范围 fade_rate_range=(0.02, 0.06), # 消失速度范围 colors=None, # 气泡颜色列表 **kwargs ): # 初始化代码... def create_bubble(self): # 创建单个气泡的代码... def interpolate_mobject(self, alpha): # 控制气泡动画效果的核心代码...

1.2. 气泡创建机制

__init__方法中,我们首先定义了一系列参数,如气泡数量、大小范围、上升速度等,然后创建一个VGroup来存放所有气泡:

# 创建气泡组 self.bubbles = VGroup() self.bubble_count = bubble_count self.bubble_size_range = bubble_size_range self.rise_speed_range = rise_speed_range self.growth_rate_range = growth_rate_range self.fade_rate_range = fade_rate_range self.colors = colors or [RED, BLUE, GREEN, YELLOW, PURPLE, ORANGE] # 保存运行时间,从kwargs中获取或使用默认值 self.run_time = kwargs.get("run_time", 5.0) # 初始化气泡 for _ in range(bubble_count): bubble = self.create_bubble() self.bubbles.add(bubble) # 调用父类初始化 super().__init__(self.bubbles, **kwargs)

每个气泡通过create_bubble方法创建,该方法随机设置气泡的大小、颜色和初始位置,并为每个气泡分配独立的上升速度、生长速度和消失速度:

def create_bubble(self): """创建单个彩色气泡""" # 随机大小 size = random.uniform(*self.bubble_size_range) # 随机颜色 color = random.choice(self.colors) # 创建圆形气泡 bubble = Circle(radius=size, color=color, fill_opacity=0.4, stroke_width=2) # 随机初始位置(底部区域) x_pos = random.uniform(-config.frame_width / 2 + 1, config.frame_width / 2 - 1) y_pos = random.uniform(-config.frame_height / 2, -config.frame_height / 2 + 2) bubble.move_to([x_pos, y_pos, 0]) # 存储气泡属性 bubble.rise_speed = random.uniform(*self.rise_speed_range) bubble.growth_rate = random.uniform(*self.growth_rate_range) bubble.fade_rate = random.uniform(*self.fade_rate_range) bubble.initial_radius = size return bubble

1.3. 动画插值实现

动画的核心在于interpolate_mobject方法,它控制着每个气泡在每一帧的状态变化:

def interpolate_mobject(self, alpha): """插值函数,控制彩色气泡的动画效果""" dt = 1 / config.frame_rate # 每帧的时间间隔 for bubble in self.bubbles: # 上升 bubble.shift(UP * bubble.rise_speed * dt) # 变大 bubble.scale(1 + bubble.growth_rate * dt) # 透明度变化 current_opacity = bubble.get_fill_opacity() new_opacity = current_opacity - bubble.fade_rate * dt # 如果气泡超出屏幕顶部或透明度降到0以下,则重置 if new_opacity <= 0 or bubble.get_y() > config.frame_height / 2: # 重置气泡 x_pos = random.uniform( -config.frame_width / 2 + 1, config.frame_width / 2 - 1 ) y_pos = random.uniform( -config.frame_height / 2, -config.frame_height / 2 + 2 ) bubble.move_to([x_pos, y_pos, 0]) bubble.set_fill(opacity=0.4) bubble.set_stroke(opacity=0.4) else: bubble.set_fill(opacity=new_opacity) bubble.set_stroke(opacity=new_opacity)

这个方法实现了三个关键效果:

  1. 上升:每个气泡以自己的速度向上移动
  2. 变大:每个气泡以自己的速度缓慢变大
  3. 透明度变化:每个气泡逐渐变得透明

特别值得注意的是,当气泡超出屏幕顶部或透明度降到0以下时,代码会将气泡重置到底部,从而实现循环不断的气泡效果。

2. 使用示例

代码提供了两个使用示例,分别展示了普通气泡效果和彩色气泡效果。

2.1. 普通气泡效果

SimpleBubbleEffectExample类展示了如何创建灰度的气泡效果:

class SimpleBubbleEffectExample(Scene): """普通气泡特效示例场景""" def construct(self): # 创建标题 title = Text("普通气泡特效演示", font_size=48) title.to_edge(UP) self.play(Write(title)) self.wait(0.5) bubble_effect = BubbleEffect( bubble_count=25, colors=[GRAY], # 设置为灰色 bubble_size_range=(0.1, 0.5), rise_speed_range=(0.6, 2.2), growth_rate_range=(0.1, 0.5), fade_rate_range=(0.02, 0.06), run_time=2, # 使用run_time而不是duration ) # 播放气泡特效 self.play(bubble_effect) self.wait()

2.2. 彩色气泡效果

ColorfulBubbleEffectExample类展示了如何创建彩色的气泡效果:

class ColorfulBubbleEffectExample(Scene): """彩色气泡特效示例场景""" def construct(self): # 创建标题 title = Text("彩色气泡特效演示", font_size=48) title.to_edge(UP) self.play(Write(title)) self.wait(0.5) # 创建彩色气泡特效动画 bubble_effect = BubbleEffect( bubble_count=25, bubble_size_range=(0.1, 0.5), rise_speed_range=(0.6, 2.2), growth_rate_range=(0.1, 0.5), fade_rate_range=(0.02, 0.06), run_time=2, # 使用run_time而不是duration ) # 播放彩色气泡特效
http://www.gsyq.cn/news/1611471.html

相关文章:

  • 你的输出第一行肯定和我不一样,且每次运行的输出肯定不一样。
  • — 一款针对 IT 团队开发的文档管理系统,基于 Golang 开发,内置项目管理,用户管理,权限管理等功能,可以用来储存日常接口文档,数据库字典,手册说明等文档。功能特色:
  • 零基础使用VMware虚拟机安装CentOS Linux超详细教程
  • 硬件学习第三天(阅读芯片手册)
  • 技术速递|通过全新开放数据集,加速研究人员和开发者构建多语言 AI
  • [智能体-612]:AGENTS.md 完整详解(OpenClaw 体系,对应 workspace 里的工作规范文件)
  • 中餐厅摆台 点击UI图片拖拽预制体到桌面并 实现预制体拖拽
  • 一文搞懂巴别鸟版本管理:从历史回溯到冲突解决的完整攻略
  • Keepalived简介与工作原理Keepalived是一个基于VRRP协议(虚拟路由冗余协议) 实现的高可用解
  • 23 万 Star 的秘密知识库,运维和安全人员的工具箱
  • 3个步骤让Windows 11重获新生:Win11Debloat系统优化完全指南
  • 基于STM32单片机老人防丢智能拐杖 盲人导航定位跌倒检测设计系统3(设计源文件+万字报告+讲解)(支持资料、图片参考_相关定制)_文章底部可以扫码
  • HTML和CSS基本知识
  • 大模型核心技术与企业级应用实战指南-附录
  • App Store Connect CLI 1.5.4 官方版下载(夸克网盘+百度网盘,SHA256校验)
  • 企业级数字人直播解决方案:多账号矩阵 + 全域同步推流
  • 双向链表,反转链表
  • PHP本地开发环境一键部署与API集成实践指南
  • MySQL索引深潜:从B+树到查询优化器的艺术
  • Spring Boot 3.0.5 + Vue 3 实战:手把手教你搞定WebSocket消息推送(含完整前后端代码)
  • Java中实现html转pdf
  • 2026年值得关注的AI外呼厂商盘点:从云厂商到垂直方案,怎么选更合适?
  • 3-IPV6域名解析
  • 实战掌握Adobe软件激活:全面解析GenP 3.0破解工具高效配置
  • 后端性能瓶颈排查实战:从慢接口到系统优化的完整落地思路
  • 大部分人都在管别人的闲事
  • 而 C++ 就是这种能自举的编程语言
  • 【Claude】Claude Code 代码审查实战指南:一次对话审出 26 个 Bug 的方法论
  • Go模块管理教程
  • 【最新测评】有没有降AI率的靠谱网站推荐?2026年实测15款降AI神器,省钱又高效!