fixed_stars.py 3.5 KB
Newer Older
三月三net's avatar
三月三net 已提交
1 2 3 4 5 6 7 8
# -*- coding:utf-8 -*-
# title           :恒星演示
# description     :恒星演示
# author          :Python超人
# date            :2023-02-11
# link            :https://gitcode.net/pythoncr/
# python_version  :3.8
# ==============================================================================
三月三net's avatar
三月三net 已提交
9
from bodies import Sun, Earth, Sirius, Rigel, Bellatrix, Alcyone, Antares, Arcturus, Aldebaran, Betelgeuse
三月三net's avatar
三月三net 已提交
10
from bodies import EtaCarinae, YCanumVenaticorum, VYCanisMajoris, UYScuti, CarinaeV382, Stephenson_2_18
三月三net's avatar
三月三net 已提交
11
from common.consts import SECONDS_PER_WEEK, SECONDS_PER_MONTH, SECONDS_PER_YEAR, SECONDS_PER_DAY
三月三net's avatar
三月三net 已提交
12 13 14 15 16
from scenes.func import mayavi_run, mpl_run, ursina_run
from bodies.body import Body, AU

if __name__ == '__main__':
    """
三月三net's avatar
三月三net 已提交
17
    恒星演示   
三月三net's avatar
三月三net 已提交
18 19
    """
    # 构建两个天体对象(太阳、地球)
三月三net's avatar
三月三net 已提交
20
    D = 5e5
三月三net's avatar
三月三net 已提交
21
    SIZE_SCALE = 0.5
三月三net's avatar
三月三net 已提交
22
    bodies = [
三月三net's avatar
三月三net 已提交
23 24
        Earth(size_scale=SIZE_SCALE, ignore_mass=True),
        Sun(size_scale=SIZE_SCALE, ignore_mass=True),  # 太阳
三月三net's avatar
三月三net 已提交
25
        Sirius(size_scale=SIZE_SCALE, ignore_mass=True),            # 天狼星A      质量倍数 2.02   半径倍数 1.71
三月三net's avatar
三月三net 已提交
26
        # Bellatrix(size_scale=SIZE_SCALE, ignore_mass=True),         # 参宿五       质量倍数 8.6    半径倍数 5.75
三月三net's avatar
三月三net 已提交
27 28 29 30
        Alcyone(size_scale=SIZE_SCALE, ignore_mass=True),           # 昴宿六       质量倍数 6      半径倍数 9.5
        Arcturus(size_scale=SIZE_SCALE, ignore_mass=True),          # 大角星       质量倍数 1.1    半径倍数 25.7
        Aldebaran(size_scale=SIZE_SCALE, ignore_mass=True),         # 毕宿五       质量倍数 1.16   半径倍数 44.13
        Rigel(size_scale=SIZE_SCALE, ignore_mass=True),             # 参宿七       质量倍数 18     半径倍数 78
三月三net's avatar
三月三net 已提交
31
        # YCanumVenaticorum(size_scale=SIZE_SCALE, ignore_mass=True), # 猎犬座Y      质量倍数 3.0    半径倍数 215
三月三net's avatar
三月三net 已提交
32 33 34 35 36
        EtaCarinae(size_scale=SIZE_SCALE, ignore_mass=True),        # 海山二       质量倍数 125    半径倍数 278
        # Antares(size_scale=SIZE_SCALE, ignore_mass=True),           # 心宿二       质量倍数 15     半径倍数 680
        CarinaeV382(size_scale=SIZE_SCALE, ignore_mass=True),       # 船底座V382   质量倍数 39     半径倍数 747
        # Betelgeuse(size_scale=SIZE_SCALE, ignore_mass=True),        # 参宿四       质量倍数 19     半径倍数 1180
        VYCanisMajoris(size_scale=SIZE_SCALE, ignore_mass=True),    # 大犬座VY     质量倍数 30     半径倍数 1400
三月三net's avatar
三月三net 已提交
37
        UYScuti(size_scale=SIZE_SCALE, ignore_mass=True),           # 盾牌座 UY    质量倍数 10     半径倍数 1708
三月三net's avatar
三月三net 已提交
38
        Stephenson_2_18(size_scale=SIZE_SCALE, ignore_mass=True)    # 史蒂文森2-18 质量倍数 40.0   半径倍数 2150
三月三net's avatar
三月三net 已提交
39
    ]
三月三net's avatar
三月三net 已提交
40 41
    distance_sum = 0
    for idx, body in enumerate(bodies):
三月三net's avatar
三月三net 已提交
42
        body.rotation_speed /= 10
三月三net's avatar
三月三net 已提交
43
        if body.is_fixed_star:
三月三net's avatar
三月三net 已提交
44
            body.light_on = False  # 关闭灯光效果,只有太阳对地球有灯光效果
三月三net's avatar
三月三net 已提交
45 46 47 48 49 50 51 52
        if idx == 0:
            d = 0
        else:
            d = pow((body.raduis + bodies[idx - 1].raduis) * SIZE_SCALE, 1.0) * 1.1
        # d = (body.diameter + bodies[idx - 1].diameter) * SIZE_SCALE * 1.1 + D
        body.init_velocity = [0, 0, 0]
        body.init_position = [body.raduis * SIZE_SCALE, (distance_sum + d), AU]
        distance_sum += d
三月三net's avatar
三月三net 已提交
53 54 55 56

    # 使用 ursina 查看的运行效果
    # 常用快捷键: P:运行和暂停  O:重新开始  I:显示天体轨迹
    # position = 左-右+、上+下-、前+后-
三月三net's avatar
三月三net 已提交
57
    ursina_run(bodies, SECONDS_PER_WEEK, position=(0, AU, -AU / 500), show_trail=True)