# -*- coding:utf-8 -*- # title :阋神星 # description :阋神星 # author :Python超人 # date :2023-02-11 # link :https://gitcode.net/pythoncr/ # python_version :3.8 # ============================================================================== from bodies.body import Body, AU from bodies import Earth class Eris(Body): """ 阋神星 ------------------------ 自转周期: 14.56 天 逃逸速度: 1.38km/s 轨道周期: 559.07 年 平均速度: 3.436 km/s 天体质量: 1.6466✕10²² kg 平均密度: 2.43 g/cm³ -> 2.43✕10³ kg/m³ 直 径: 2326 km 远日点 97.56 AU 14.60×109 km 近日点 37.77 AU 5.65×109 km """ def __init__(self, name="阋神星", mass=1.6466e22, init_position=[0, 0, 37.77 * AU], init_velocity=[-3.436, 0, 0], texture="eris.png", size_scale=1.0, distance_scale=1.0, rotation_speed=0, ignore_mass=False, trail_color=None, show_name=False): """ @param name: 阋神星名称 @param mass: 阋神星质量 (kg) @param init_position: 初始位置 (km) @param init_velocity: 初始速度 (km/s) @param texture: 纹理图片 @param size_scale: 尺寸缩放 @param distance_scale: 距离缩放 @param rotation_speed: 自旋速度(度/小时) @param ignore_mass: 是否忽略质量(如果为True,则不计算引力) TODO: 注意:这里的算法是基于牛顿的万有引力(质量为0不受引力的影响在天体物理学中是不严谨) @param trail_color:阋神星拖尾颜色(默认天体颜色) @param show_name: 是否显示阋神星名称 @param gravity_only_for_earth: 如果为True,则仅适用于地球的重力,与其他天体之间的重力不会受到影响 """ params = { "name": name, "mass": mass, "init_position": init_position, "init_velocity": init_velocity, "density": 2.43e3, "color": (162, 162, 162), "texture": texture, "size_scale": size_scale, "distance_scale": distance_scale, "rotation_speed": rotation_speed, "ignore_mass": ignore_mass, "trail_color": trail_color, "show_name": show_name } super().__init__(**params) if __name__ == '__main__': eris = Eris() eris.show_demo(size_scale=1000) print(eris)