《青花》歌曲,使用3D表现出意境

《青花》歌词 三月走过 柳絮散落 恋人们匆匆 我的爱情 闻风不动 翻阅昨日 仍有温度 蒙尘的心事 恍恍惚惚 已经隔世 遗憾无法说 惊觉心一缩 紧紧握着 青花信物 信守着承诺 离别总在 失意中度过 记忆油膏 反复涂抹 无法愈合的伤口 你的回头 划伤了沉默 那夜重逢 停止漂泊 你曾回来过 相濡相忘 都是疼痛 只因昨日 善良固执 委屈着彼此 打碎信物 取消来世 遗憾无法说 惊觉心一缩 紧紧握着 青花信物 信守着承诺 离别总在 失意中度过 记忆油膏 反复涂抹 无法愈合的伤口 你的回头 划伤了沉默 紧紧握着 青花信物 雕刻着寂寞 就好像我 无主的魂魄 纠缠过往 无端神伤 摔碎谁也带不走 你我一场 唤不醒的梦 紧紧握着 青花信物 信守着承诺 离别总在 失意中度过 记忆油膏 反复涂抹 无法愈合的伤口 你的回头 划伤了沉默 紧紧握着 青花信物 雕刻着寂寞 就好像我 无主的魂魄 纠缠过往 无端神伤 摔碎谁也带不走 你我一场 唤不醒的梦 。

复制代码
import numpy as np
import matplotlib.pyplot as plt
from mpl_toolkits.mplot3d import Axes3D
import matplotlib.animation as animation

# 设置中文字体
plt.rcParams['font.sans-serif'] = ['SimHei']
plt.rcParams['axes.unicode_minus'] = False

# 创建图形和3D轴
fig = plt.figure(figsize=(12, 9))
ax = fig.add_subplot(111, projection='3d')

# 设置简洁的背景色
fig.patch.set_facecolor('#f8f8ff')
ax.set_facecolor('#fafafa')

# 设置标题
ax.set_title('《青花》意境', fontsize=18, color='#2f4f4f', pad=20)

# 隐藏坐标轴
ax.set_axis_off()

# 设置视角
ax.view_init(elev=25, azim=-70)


# 创建简化的青花瓷瓶
def create_vase(u, v):
    r = 1.2 * np.sin(np.pi * v) + 0.1 * np.sin(3 * u)
    x = r * np.cos(u)
    y = r * np.sin(u)
    z = 2.5 * (v - 0.5)
    return x, y, z


# 生成花瓶的网格
u = np.linspace(0, 2 * np.pi, 40)
v = np.linspace(0, 1, 25)
U, V = np.meshgrid(u, v)
X, Y, Z = create_vase(U, V)

# 绘制青花瓷瓶 - 使用更简洁的样式
vase = ax.plot_surface(X, Y, Z, color='#f0f8ff', alpha=0.95,
                       edgecolor='#4682b4', linewidth=0.8, shade=True)

# 添加简单的青花图案
pattern_u = np.linspace(0, 2 * np.pi, 8)
pattern_v = np.linspace(0.3, 0.7, 3)
for pu in pattern_u:
    for pv in pattern_v:
        px, py, pz = create_vase(pu, pv)
        # 绘制简单的蓝色圆点作为花纹
        ax.scatter([px], [py], [pz], color='#4682b4', s=30, alpha=0.8)

# 创建少量柳絮(简化版)
n_pollen = 30
pollen_x = np.random.uniform(-3, 3, n_pollen)
pollen_y = np.random.uniform(-3, 3, n_pollen)
pollen_z = np.random.uniform(-1, 4, n_pollen)
pollen_sizes = np.random.uniform(20, 40, n_pollen)

pollen = ax.scatter(pollen_x, pollen_y, pollen_z,
                    c='#dcdcdc', s=pollen_sizes, alpha=0.7)

# 创建少量记忆光点
n_lights = 15
light_x = np.random.uniform(-2, 2, n_lights)
light_y = np.random.uniform(-2, 2, n_lights)
light_z = np.random.uniform(-1, 3, n_lights)
light_sizes = np.random.uniform(30, 60, n_lights)
light_colors = ['#ffd700', '#ffa500', '#ff8c00']

light_colors_array = np.random.choice(light_colors, n_lights)
lights = ax.scatter(light_x, light_y, light_z,
                    c=light_colors_array, s=light_sizes, alpha=0.6)

# 添加简洁的裂纹效果(象征伤口)
crack_x = np.array([2.8, 3.0, 3.2, 3.4])
crack_z = np.array([0.0, -0.2, 0.1, -0.1])
crack_y = 0.1 * np.sin(5 * crack_x)
ax.plot(crack_x, crack_y, crack_z, color='#8b0000', linewidth=2, alpha=0.7)

# 只显示关键歌词,放置在不干扰主体的位置
key_lyrics = [
    ("三月走过 柳絮散落", (-4, -3.5, 3.5)),
    ("紧紧握着 青花信物", (-4, -3.5, 2.5)),
    ("记忆反复 无法愈合", (-4, -3.5, 1.5)),
    ("你我一场 唤不醒的梦", (-4, -3.5, 0.5))
]

for text, pos in key_lyrics:
    ax.text(pos[0], pos[1], pos[2], text, fontsize=11, color='#2f4f4f',
            ha='left', va='center', fontfamily='serif', alpha=0.8)

# 设置坐标轴范围
ax.set_xlim(-4, 4)
ax.set_ylim(-4, 4)
ax.set_zlim(-2, 4)


# 简化动画效果
def animate(frame):
    # 柳絮缓慢飘动
    pollen_z_new = pollen_z + 0.03 * np.sin(frame * 0.08 + np.arange(n_pollen) * 0.2)
    mask = pollen_z_new > 4
    pollen_z_new[mask] = -1
    pollen._offsets3d = (pollen_x, pollen_y, pollen_z_new)

    # 记忆光点缓慢闪烁
    scale = 0.8 + 0.4 * np.sin(frame * 0.1 + np.arange(n_lights) * 0.3)
    current_sizes = light_sizes * scale
    lights.set_sizes(current_sizes)

    # 缓慢旋转视角
    ax.view_init(elev=25, azim=-70 + frame * 0.3)

    return pollen, lights


# 创建动画
ani = animation.FuncAnimation(fig, animate, frames=360, interval=50, blit=False)

plt.tight_layout()
plt.show()
相关推荐
知秋一叶1239 分钟前
Miloco 深度打通 Home Assistant,实现设备级精准控制
人工智能·智能家居
春日见30 分钟前
在虚拟机上面无法正启动机械臂的控制launch文件
linux·运维·服务器·人工智能·驱动开发·ubuntu
————A42 分钟前
强化学习----->轨迹、回报、折扣因子和回合
人工智能·python
CareyWYR1 小时前
每周AI论文速递(251215-251219)
人工智能
weixin_409383122 小时前
在kaggle训练Qwen/Qwen2.5-1.5B-Instruct 通过中二时期qq空间记录作为训练数据 训练出中二的模型为目标 第一次训练 好像太二了
人工智能·深度学习·机器学习·qwen
JoannaJuanCV2 小时前
自动驾驶—CARLA仿真(22)manual_control_steeringwheel demo
人工智能·自动驾驶·pygame·carla
余俊晖2 小时前
使用Agent做本体匹配的架构设计
人工智能·语言模型·自然语言处理
科士威传动2 小时前
方形滚珠导轨如何保障高速定位精度?
人工智能·科技·机器人·自动化·制造
SmartBrain2 小时前
洞察:阿里通义DeepResearch 技术
大数据·人工智能·语言模型·架构
声声codeGrandMaster2 小时前
AI之模型提升
人工智能·pytorch·python·算法·ai