three_body_02.py 1.4 KB
Newer Older
M
march3 已提交
1 2 3 4
# -*- coding:utf-8 -*-
# title           :太阳系场景
# description     :
# author          :Python超人
M
march3 已提交
5 6
# date            :2023-02-11
# link            :https://gitcode.net/pythoncr/
M
march3 已提交
7 8 9
# python_version  :3.8
# ==============================================================================
from mayavi import mlab
M
march3 已提交
10 11 12
from bodies import Sun, Earth
from common.consts import SECONDS_PER_WEEK
from scenes.func import mayavi_run
M
march3 已提交
13 14

if __name__ == '__main__':
M
march3 已提交
15 16 17 18 19 20 21
    """
    3个太阳、1个地球(效果2)
    可以修改影响效果的参数为: 
    1、三个方向的初始位置 init_position[x, y, z]
    2、三个方向的初始速度 init_velocity[x, y, z]
    3、天体质量 mass    
    """
M
march3 已提交
22
    bodies = [
M
march3 已提交
23 24 25 26 27 28
        Sun(mass=5e30, init_position=[649597870.700, 0, 0], init_velocity=[0, 5.0, 0],
            size_scale=5e1, texture="sun1.jpg"),  # 太阳放大 100 倍
        Sun(mass=4e30, init_position=[0, 0, 249597870.700], init_velocity=[0, -6.0, 0],
            size_scale=5e1, texture="sun2.jpg"),  # 太阳放大 100 倍
        Sun(mass=3e30, init_position=[0, -649597870.700, 0], init_velocity=[6.0, 0, 0],
            size_scale=5e1, texture="sun2.jpg"),  # 太阳放大 100 倍
M
march3 已提交
29

M
march3 已提交
30
        Earth(init_position=[0, -249597870.700, 0], init_velocity=[15.50, 0, 0],
M
march3 已提交
31
              size_scale=4e3, distance_scale=1),  # 地球放大 4000 倍,距离保持不变
M
march3 已提交
32
    ]
M
march3 已提交
33
    mayavi_run(bodies, SECONDS_PER_WEEK, view_azimuth=0)