-
Notifications
You must be signed in to change notification settings - Fork 101
/
Copy pathPlanetary_System_Visualization.py
131 lines (98 loc) · 4.21 KB
/
Planetary_System_Visualization.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
import math
import pygame
SCREEN_WIDTH = 2160
SCREEN_HEIGHT = 2160
SUN_RADIUS = 50
# Planet data: name, radius, orbit radius, orbit speed, color
PLANETS = [
("Mercury", 10, 100, 0.02, (128, 128, 128)),
("Venus", 15, 150, 0.015, (255, 165, 0)),
("Earth", 20, 200, 0.01, (0, 0, 255)),
("Mars", 17, 250, 0.008, (255, 0, 0)),
("Jupiter", 40, 350, 0.005, (255, 215, 0)),
("Saturn", 35, 450, 0.004, (210, 180, 140)),
("Uranus", 30, 550, 0.003, (0, 255, 255)),
("Neptune", 30, 650, 0.002, (0, 0, 139)),
("Pluto", 8, 750, 0.001, (165, 42, 42))
]
class CelestialBody:
def __init__(self, name, radius, orbit_radius, orbit_speed, color):
self.name = name
self.radius = radius
self.orbit_radius = orbit_radius
self.orbit_speed = orbit_speed
self.color = color
self.angle = 0
def update(self, dt):
self.angle += self.orbit_speed * dt
def get_position(self):
x = SCREEN_WIDTH // 2 + math.cos(self.angle) * self.orbit_radius
y = SCREEN_HEIGHT // 2 + math.sin(self.angle) * self.orbit_radius
return x, y
def calculate_volume(self):
volume = (4 / 3) * math.pi * self.radius ** 3
return volume
def calculate_surface_area(self):
surface_area = 4 * math.pi * self.radius ** 2
return surface_area
def calculate_orbital_velocity(self):
if self.orbit_speed == 0:
return float('inf')
orbital_velocity = 2 * math.pi * self.orbit_radius / self.orbit_speed
return orbital_velocity
def create_celestial_body(name, radius, orbit_radius, orbit_speed, color):
return CelestialBody(name, radius, orbit_radius, orbit_speed, color)
def draw_celestial_body(screen, body):
x, y = body.get_position()
# Display the name
name_text = body.name
name_font = pygame.font.SysFont("Arial", 16)
name_surface = name_font.render(name_text, True, (255, 255, 255))
name_rect = name_surface.get_rect(center=(int(x), int(y) + body.radius + 20))
screen.blit(name_surface, name_rect)
# Perform scientific calculations for each planet
volume = body.calculate_volume()
surface_area = body.calculate_surface_area()
orbital_velocity = body.calculate_orbital_velocity()
# Display the calculations
calc_font = pygame.font.SysFont("Arial", 14)
volume_text = f"Volume: {volume:.2f}"
volume_surface = calc_font.render(volume_text, True, (255, 255, 255))
volume_rect = volume_surface.get_rect(center=(int(x), int(y) + body.radius + 40))
screen.blit(volume_surface, volume_rect)
surface_area_text = f"Surface Area: {surface_area:.2f}"
surface_area_surface = calc_font.render(surface_area_text, True, (255, 255, 255))
surface_area_rect = surface_area_surface.get_rect(center=(int(x), int(y) + body.radius + 55))
screen.blit(surface_area_surface, surface_area_rect)
orbital_velocity_text = f"Orbital Velocity: {orbital_velocity:.2f}"
orbital_velocity_surface = calc_font.render(orbital_velocity_text, True, (255, 255, 255))
orbital_velocity_rect = orbital_velocity_surface.get_rect(center=(int(x), int(y) + body.radius + 70))
screen.blit(orbital_velocity_surface, orbital_velocity_rect)
# Draw the body
pygame.draw.circle(screen, body.color, (int(x), int(y)), body.radius)
def main():
pygame.init()
screen = pygame.display.set_mode((SCREEN_WIDTH, SCREEN_HEIGHT))
pygame.display.set_caption("Planetary System")
clock = pygame.time.Clock()
sun = create_celestial_body("Sun", SUN_RADIUS, 0, 0, (255, 255, 0))
planets = []
for planet_data in PLANETS:
name, radius, orbit_radius, orbit_speed, color = planet_data
planet = create_celestial_body(name, radius, orbit_radius, orbit_speed, color)
planets.append(planet)
is_running = True
while is_running:
dt = clock.tick(60) / 60.0
for event in pygame.event.get():
if event.type == pygame.QUIT:
is_running = False
screen.fill((0, 0, 0))
for planet in planets:
planet.update(dt)
draw_celestial_body(screen, planet)
draw_celestial_body(screen, sun)
pygame.display.flip()
pygame.quit()
if __name__ == "__main__":
main()