提交 5dcd3d63 编写于 作者: 三月三net's avatar 三月三net

Python超人-宇宙模拟器

上级 b231dfab
......@@ -35,7 +35,7 @@ class JupiterProtectsEarthSim:
self.comets = []
self.comet_radius = self.jupiter.position[2] * 2
self.comet_radius = self.jupiter.position[2] * 1.5
for i in range(comet_num):
# 随机生成 comet_num 个石头
......@@ -52,8 +52,8 @@ class JupiterProtectsEarthSim:
# -radius * random.randint(120, 200) / 1000,
# -radius * random.randint(100, 300) / 100]
x = radius * math.cos(random.uniform(0, 2 * math.pi)) * random.randint(80, 150) / 100
z = radius * math.sin(random.uniform(0, 2 * math.pi)) * random.randint(80, 150) / 100
x = radius * math.cos(random.uniform(0, 2 * math.pi)) * (random.randint(100, 150) / 100)
z = radius * math.sin(random.uniform(0, 2 * math.pi)) * (random.randint(100, 150) / 100)
pos = [x, 0, z]
# 随机速度
......@@ -94,7 +94,7 @@ class JupiterProtectsEarthSim:
# 如果是否可见,则旋转石头
comet.planet.rotation += comet.rotation
# 循环判断每个石头与木星是否相碰撞,如果相碰撞就爆炸
if two_bodies_colliding(comet, self.jupiter):
if not hasattr(comet, "jupiter_collided") and two_bodies_colliding(comet, self.jupiter):
# 将石头隐藏、设置引力无效后,展示爆炸效果
# comet.explode(self.jupiter)
# 碰撞到木星,该石头不要爆炸,尝试看看是否会碰撞到地球,如果碰撞了地球,则“木星保护”统计加一
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册