Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Python_超人
宇宙模拟器
提交
cf8c6ee1
宇宙模拟器
项目概览
Python_超人
/
宇宙模拟器
通知
19
Star
2
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
宇宙模拟器
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
cf8c6ee1
编写于
10月 27, 2023
作者:
三月三net
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Python超人-宇宙模拟器
上级
f87304ac
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
98 addition
and
2 deletion
+98
-2
sim_scenes/funny/black_holes_control_stars.py
sim_scenes/funny/black_holes_control_stars.py
+2
-2
sim_scenes/funny/black_holes_control_stars_01.py
sim_scenes/funny/black_holes_control_stars_01.py
+96
-0
未找到文件。
sim_scenes/funny/black_holes_control_stars.py
浏览文件 @
cf8c6ee1
# -*- coding:utf-8 -*-
# -*- coding:utf-8 -*-
# title :
三体场景模拟02
# title :
黑洞模拟
# description :
三体场景模拟(3个太阳、1个地球)
# description :
黑洞模拟
# author :Python超人
# author :Python超人
# date :2023-07-26
# date :2023-07-26
# link :https://gitcode.net/pythoncr/
# link :https://gitcode.net/pythoncr/
...
...
sim_scenes/funny/black_holes_control_stars_01.py
0 → 100644
浏览文件 @
cf8c6ee1
# -*- coding:utf-8 -*-
# title :黑洞模拟
# description :黑洞模拟
# author :Python超人
# date :2023-10-27
# link :https://gitcode.net/pythoncr/
# python_version :3.8
# ==============================================================================
from
bodies
import
Sun
,
Earth
from
common.consts
import
SECONDS_PER_DAY
,
SECONDS_PER_WEEK
,
SECONDS_PER_YEAR
,
AU
from
sim_scenes.func
import
mayavi_run
,
mpl_run
,
ursina_run
,
create_sphere_sky
from
bodies
import
FixedStar
,
Body
from
simulators.ursina.entities.body_timer
import
TimeData
from
simulators.ursina.ursina_event
import
UrsinaEvent
class
BlackHole
(
FixedStar
):
def
__init__
(
self
,
name
=
"黑洞"
,
mass
=
1.9891e35
,
init_position
=
[
0
,
0
,
0
],
init_velocity
=
[
0
,
0
,
0
],
color
=
(
0
,
0
,
0
),
# texture="cosmic3.jpg", # 虫洞
texture
=
""
,
# 黑洞
size_scale
=
1.0
,
distance_scale
=
1.0
,
rotation_speed
=
0.6130
,
ignore_mass
=
False
,
trail_color
=
None
,
show_name
=
False
):
params
=
{
"name"
:
name
,
"mass"
:
mass
,
"init_position"
:
init_position
,
"init_velocity"
:
init_velocity
,
"density"
:
1.408e20
,
"color"
:
color
,
"texture"
:
texture
,
"size_scale"
:
size_scale
*
10000
,
"distance_scale"
:
distance_scale
,
"rotation_speed"
:
rotation_speed
,
"ignore_mass"
:
ignore_mass
,
"trail_color"
:
trail_color
,
"show_name"
:
show_name
}
super
().
__init__
(
**
params
)
# self.glows = (0, 1.015, 0.08, (255, 255, 255))
if
__name__
==
'__main__'
:
"""
注释: 3个太阳
可以修改影响效果的参数为:
1、三个方向的初始位置 init_position[x, y, z]
2、三个方向的初始速度 init_velocity[x, y, z]
3、天体质量 mass
"""
# 代码案例如下:
SIZE_SCALE
=
5e1
# 生成的太阳放大 50 倍
RUN_DIAMETER
=
1.392e6
# 真实太阳的直径
velocity_rate
=
11000
bodies
=
[
Sun
(
name
=
"太阳1"
,
mass
=
1e30
,
color
=
(
111
,
140
,
255
),
rotation_speed
=
0.1
,
init_position
=
[
-
100
*
RUN_DIAMETER
,
0
,
0
],
init_velocity
=
[
0.347113
*
velocity_rate
,
0.532727
*
velocity_rate
,
0
],
size_scale
=
SIZE_SCALE
,
texture
=
"fixed_star.png"
),
BlackHole
(
init_position
=
[
-
100
*
RUN_DIAMETER
,
100
*
RUN_DIAMETER
,
0
],
size_scale
=
SIZE_SCALE
/
5
)
]
def
on_ready
():
from
ursina
import
camera
,
application
# 创建天空
# camera.clip_plane_near = 0.1
camera
.
clip_plane_far
=
1000000
create_sphere_sky
(
scale
=
200000
)
application
.
time_scale
=
3
def
on_timer_changed
(
time_data
:
TimeData
):
pass
# 订阅事件后,上面2个函数功能才会起作用
# 运行前会触发 on_ready
UrsinaEvent
.
on_ready_subscription
(
on_ready
)
# 运行中,每时每刻都会触发 on_timer_changed
UrsinaEvent
.
on_timer_changed_subscription
(
on_timer_changed
)
# 使用 ursina 查看的运行效果
# 常用快捷键: P:运行和暂停 O:重新开始 I:显示天体轨迹
# position = 左-右+、上+下-、前+后-
ursina_run
(
bodies
,
SECONDS_PER_DAY
/
24
,
position
=
(
-
1.5
*
AU
,
0
,
-
5
*
AU
),
show_grid
=
False
,
show_camera_info
=
False
,
show_control_info
=
False
,
cosmic_bg
=
''
,
show_trail
=
True
)
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录