太空飞船任务,生成一个地球发射、火星着陆以及下一次发射窗口返回地球的动画3D代码


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

# 天体参数设置(简化模型)
AU = 1.5e8  # 天文单位(公里)
earth_orbital_radius = 1.0 * AU
mars_orbital_radius = 1.5 * AU
orbital_speed = 2e4  # 简化轨道速度(km/s)

# 时间参数
earth_period = 365  # 天
mars_period = 687  # 天
transfer_time = 258  # 霍曼转移时间(天)
time_step = 2  # 动画时间步长(天)
total_duration = 800  # 总任务时间(天)

# 初始化图形
fig = plt.figure(figsize=(10, 8))
ax = fig.add_subplot(111, projection='3d')
ax.set_facecolor('black')


# 天体初始位置
def celestial_pos(t, period, radius):
    angle = 2 * np.pi * t / period
    return radius * np.array([np.cos(angle), np.sin(angle), 0])


# 霍曼转移轨道计算
def transfer_orbit(t, t_start, radius_from, radius_to, transfer_time):
    angle = np.pi * (t - t_start) / transfer_time
    r = radius_from + (radius_to - radius_from) * (t - t_start) / transfer_time
    return r * np.array([np.cos(angle), np.sin(angle), 0])


# 初始化绘图元素
earth, = ax.plot([], [], [], 'o', color='blue', markersize=8)
mars, = ax.plot([], [], [], 'o', color='red', markersize=6)
ship, = ax.plot([], [], [], 'o', color='white', markersize=4)
trajectory, = ax.plot([], [], [], '-', color='gray', alpha=0.5)
sun = ax.plot([0], [0], [0], 'o', color='yellow', markersize=12)[0]

# 坐标轴设置
max_orbit = mars_orbital_radius * 1.2
ax.set_xlim(-max_orbit, max_orbit)
ax.set_ylim(-max_orbit, max_orbit)
ax.set_zlim(-max_orbit / 10, max_orbit / 10)
ax.axis('off')


# 动画更新函数
def update(frame):
    t = frame * time_step

    # 更新天体位置
    earth_pos = celestial_pos(t, earth_period, earth_orbital_radius)
    earth.set_data(earth_pos[0], earth_pos[1])
    earth.set_3d_properties(0)

    mars_pos = celestial_pos(t, mars_period, mars_orbital_radius)
    mars.set_data(mars_pos[0], mars_pos[1])
    mars.set_3d_properties(0)

    # 飞船状态机
    if t < transfer_time:  # 前往火星阶段
        ship_pos = transfer_orbit(t, 0, earth_orbital_radius, mars_orbital_radius, transfer_time)
    elif t < transfer_time + 30:  # 火星停留
        ship_pos = mars_pos
    else:  # 返回地球阶段
        ship_pos = transfer_orbit(t - transfer_time - 30, 0, mars_orbital_radius, earth_orbital_radius, transfer_time)

    ship.set_data(ship_pos[0], ship_pos[1])
    ship.set_3d_properties(0)

    # 更新轨迹
    x, y, z = trajectory.get_data_3d()
    x = np.append(x, ship_pos[0])
    y = np.append(y, ship_pos[1])
    z = np.append(z, 0)
    trajectory.set_data(x, y)
    trajectory.set_3d_properties(z)

    return earth, mars, ship, trajectory, sun


# 创建动画
ani = FuncAnimation(fig, update, frames=int(total_duration / time_step),
                    interval=50, blit=True)

# 添加图例和标注
ax.text(0, 0, 0, "SUN", color='yellow', ha='center')
ax.text(earth_orbital_radius, 0, 0, "Earth", color='blue')
ax.text(mars_orbital_radius, 0, 0, "Mars", color='red')

plt.show()
相关推荐
aini_lovee7 小时前
基于MATLAB的雷达系统设计中的信号处理程序
算法·3d
SCADA组态软件(2D,3D)1 天前
又一款免费在线三维设计/家装设计/建筑设计/工业场景设计上线了
3d·ihomeware·家装设计·工业三维设计
新启航-光学3D测量1 天前
逆向抄数工程师能力矩阵:设备操作(±0.05mm 精度)× 曲面重构 ×GD&T 公差分析
科技·3d·制造
DDC楼宇自控与IBMS集成系统解读1 天前
BA 楼宇自控系统 + AI:重构楼宇设备管理的 “智能决策” 体系
大数据·网络·数据库·人工智能·3d·重构
CodeCraft Studio3 天前
3D文档控件Aspose.3D实用教程:使用 C# 构建 OBJ 到 U3D 转换器
开发语言·3d·c#·3d渲染·aspose·3d文件格式转换·3d sdk
郝学胜-神的一滴3 天前
Horse3D游戏引擎研发笔记(七):在QtOpenGL环境下,使用改进的Uniform变量管理方式绘制多彩四边形
c++·3d·unity·游戏引擎·图形渲染·虚幻·unreal engine
视觉语言导航3 天前
上科大解锁城市建模新视角!AerialGo:从航拍视角到地面漫步的3D城市重建
人工智能·3d·具身智能
初岘4 天前
自动驾驶GOD:3D空间感知革命
人工智能·3d·自动驾驶
SYNCON24 天前
[新启航]白光干涉仪与激光干涉仪的区别及应用解析
科技·3d·制造
Struart_R6 天前
LLaVA-3D,Video-3D LLM,VG-LLM,SPAR论文解读
人工智能·深度学习·计算机视觉·3d·大语言模型·多模态