# IT2202 - 03 Laboratory Exercise 1: Pygame and OpenGL
# Text-based simulation for online compilers (OneCompiler compatible)
# This version demonstrates the cube structure without graphics libraries
import math
import time
class Cube3D:
"""
Simulates a 3D cube with rotation capabilities using text output
"""
def __init__(self):
# Step 14: Define the 8 vertices of the cube (same as lab manual)
self.vertices = [
[1, 1, 1], # Vertex 0: X=1, Y=1, Z=1
[1, 1, -1], # Vertex 1: X=1, Y=1, Z=-1
[1, -1, -1], # Vertex 2: X=1, Y=-1, Z=-1
[1, -1, 1], # Vertex 3: X=1, Y=-1, Z=1
[-1, 1, 1], # Vertex 4: X=-1, Y=1, Z=1
[-1, -1, -1], # Vertex 5: X=-1, Y=-1, Z=-1
[-1, -1, 1], # Vertex 6: X=-1, Y=-1, Z=1
[-1, 1, -1] # Vertex 7: X=-1, Y=1, Z=-1
]
# Step 15: Define the edges connecting pairs of vertices
self.edges = [
(0, 1), # Edge A: Vertex 0 to Vertex 1
(1, 2), # Edge B: Vertex 1 to Vertex 2
(2, 3), # Edge C: Vertex 2 to Vertex 3
(3, 0), # Edge D: Vertex 3 to Vertex 0
(4, 7), # Edge E: Vertex 4 to Vertex 7
(7, 5), # Edge F: Vertex 7 to Vertex 5
(5, 6), # Edge G: Vertex 5 to Vertex 6
(6, 4), # Edge H: Vertex 6 to Vertex 4
(3, 6), # Edge I: Vertex 3 to Vertex 6
(0, 4), # Edge J: Vertex 0 to Vertex 4
(2, 5), # Edge K: Vertex 2 to Vertex 5
(1, 7) # Edge L: Vertex 1 to Vertex 7
]
self.rotation_angle = 0
def rotate_vertex(self, vertex, angle_x, angle_y, angle_z):
"""
Step 16: Simulate glRotatef() - Rotate a vertex around x, y, z axes
"""
x, y, z = vertex
# Rotation around X-axis
cos_x, sin_x = math.cos(angle_x), math.sin(angle_x)
y_new = y * cos_x - z * sin_x
z_new = y * sin_x + z * cos_x
y, z = y_new, z_new
# Rotation around Y-axis
cos_y, sin_y = math.cos(angle_y), math.sin(angle_y)
x_new = x * cos_y + z * sin_y
z_new = -x * sin_y + z * cos_y
x, z = x_new, z_new
# Rotation around Z-axis
cos_z, sin_z = math.cos(angle_z), math.sin(angle_z)
x_new = x * cos_z - y * sin_z
y_new = x * sin_z + y * cos_z
x, y = x_new, y_new
return [x, y, z]
def get_rotated_vertices(self):
"""
Apply rotation to all vertices
"""
angle = math.radians(self.rotation_angle)
rotated = []
for vertex in self.vertices:
rotated_vertex = self.rotate_vertex(vertex, angle, angle, angle)
rotated.append(rotated_vertex)
return rotated
def display_cube_info(self):
"""
Display cube structure and current state
"""
print("\n" + "="*60)
print("IT2202 - Lab Exercise 1: 3D Wireframe Cube")
print("="*60)
# Display original vertices (as specified in lab manual)
print("\nOriginal Vertices (Lab Manual Table):")
print("Vertex | X | Y | Z ")
print("-------|----|----|----")
for i, vertex in enumerate(self.vertices):
print(" {} | {:2} | {:2} | {:2}".format(i, vertex[0], vertex[1], vertex[2]))
# Display edges
print("\nEdges (Connecting Vertex Pairs):")
edge_names = ['A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L']
for i, (v1, v2) in enumerate(self.edges):
print("Edge {}: Vertex {} ↔ Vertex {}".format(edge_names[i], v1, v2))
# Display current rotation
rotated_vertices = self.get_rotated_vertices()
print("\nCurrent Rotation Angle: {}°".format(self.rotation_angle))
print("\nRotated Vertices (Current Frame):")
print("Vertex | X | Y | Z ")
print("-------|---------|---------|--------")
for i, vertex in enumerate(rotated_vertices):
print(" {} | {:7.3f} | {:7.3f} | {:7.3f}".format(i, vertex[0], vertex[1], vertex[2]))
def simple_projection(self, vertex):
"""
Simple 2D projection for text visualization
"""
x, y, z = vertex
# Simple orthographic projection (ignore z for 2D display)
screen_x = int(x * 10 + 20) # Scale and center
screen_y = int(-y * 5 + 10) # Scale, flip Y, and center
return screen_x, screen_y
def draw_ascii_cube(self):
"""
Draw a simple ASCII representation of the cube
"""
print("\nASCII Cube Projection (Top View):")
print("(Simulating pygame.display and OpenGL rendering)")
# Create a simple grid
grid = [[' ' for _ in range(40)] for _ in range(20)]
rotated_vertices = self.get_rotated_vertices()
# Mark vertices on the grid
for i, vertex in enumerate(rotated_vertices):
x, y = self.simple_projection(vertex)
if 0 <= x < 40 and 0 <= y < 20:
grid[y][x] = str(i)
# Draw the grid
for row in grid:
print(''.join(row))
print("\nNumbers 0-7 represent the cube vertices")
print("This simulates what you would see in the OpenGL window")
def simulate_pygame_loop():
"""
Step 11: Simulate the main pygame event loop
"""
cube = Cube3D()
print("Starting IT2202 Lab Exercise 1 Simulation...")
print("(This simulates pygame.init() and OpenGL setup)")
print("\nSimulating continuous rotation...")
print("In real OpenGL: glRotatef(1, 1, 1, 1) would rotate 1° around vector (1,1,1)")
print("\nPress Ctrl+C to stop the simulation")
try:
# Simulate the main loop (show 5 frames instead of infinite)
for frame in range(5):
print("\n{} FRAME {} {}".format("="*20, frame + 1, "="*20))
# Step 16: Simulate glRotatef(1, 1, 1, 1)
cube.rotation_angle += 15 # Increase by 15° each frame for visibility
# Step 11: Simulate glClear() and drawing
cube.display_cube_info()
cube.draw_ascii_cube()
# Step 11: Simulate pygame.time.wait(15)
if frame < 4: # Don't wait on last frame
print("\n[Simulating pygame.time.wait(15)...]")
time.sleep(1) # Reduced delay for demo
print("\n{}".format("="*60))
print("Simulation complete!")
print("In real OpenGL, this would show a smoothly rotating 3D wireframe cube")
print("{}".format("="*60))
except KeyboardInterrupt:
print("\nSimulation stopped by user")
print("(Simulates pygame.quit() when window is closed)")
def main():
"""
Main function demonstrating all lab concepts
"""
print("IT2202 - 03 Laboratory Exercise 1")
print("Pygame and OpenGL Simulation for Online Compilers")
print("="*60)
# Show what would normally require package installation
required_packages = ["pygame", "numpy", "PyOpenGL", "PyOpenGL_accelerate"]
print("Required packages (not available in online compilers): {}".format(', '.join(required_packages)))
print("Install locally with: py -m pip install {}".format(" ".join(required_packages)))
# Demonstrate the lab concepts
simulate_pygame_loop()
if __name__ == "__main__":
main()
# IT2202 - 03 Laboratory Exercise 1: Pygame and OpenGL
# Text-based simulation for online compilers (OneCompiler compatible)
# This version demonstrates the cube structure without graphics libraries
 
import math
import time
 
class Cube3D:
    """
    Simulates a 3D cube with rotation capabilities using text output
    """
 
    def __init__(self):
        # Step 14: Define the 8 vertices of the cube (same as lab manual)
        self.vertices = [
            [1, 1, 1],      # Vertex 0: X=1, Y=1, Z=1
            [1, 1, -1],     # Vertex 1: X=1, Y=1, Z=-1
            [1, -1, -1],    # Vertex 2: X=1, Y=-1, Z=-1
            [1, -1, 1],     # Vertex 3: X=1, Y=-1, Z=1
            [-1, 1, 1],     # Vertex 4: X=-1, Y=1, Z=1
            [-1, -1, -1],   # Vertex 5: X=-1, Y=-1, Z=-1
            [-1, -1, 1],    # Vertex 6: X=-1, Y=-1, Z=1
            [-1, 1, -1]     # Vertex 7: X=-1, Y=1, Z=-1
        ]
 
        # Step 15: Define the edges connecting pairs of vertices
        self.edges = [
            (0, 1),  # Edge A: Vertex 0 to Vertex 1
            (1, 2),  # Edge B: Vertex 1 to Vertex 2
            (2, 3),  # Edge C: Vertex 2 to Vertex 3
            (3, 0),  # Edge D: Vertex 3 to Vertex 0
            (4, 7),  # Edge E: Vertex 4 to Vertex 7
            (7, 5),  # Edge F: Vertex 7 to Vertex 5
            (5, 6),  # Edge G: Vertex 5 to Vertex 6
            (6, 4),  # Edge H: Vertex 6 to Vertex 4
            (3, 6),  # Edge I: Vertex 3 to Vertex 6
            (0, 4),  # Edge J: Vertex 0 to Vertex 4
            (2, 5),  # Edge K: Vertex 2 to Vertex 5
            (1, 7)   # Edge L: Vertex 1 to Vertex 7
        ]
 
        self.rotation_angle = 0
 
    def rotate_vertex(self, vertex, angle_x, angle_y, angle_z):
        """
        Step 16: Simulate glRotatef() - Rotate a vertex around x, y, z axes
        """
        x, y, z = vertex
 
        # Rotation around X-axis
        cos_x, sin_x = math.cos(angle_x), math.sin(angle_x)
        y_new = y * cos_x - z * sin_x
        z_new = y * sin_x + z * cos_x
        y, z = y_new, z_new
 
        # Rotation around Y-axis
        cos_y, sin_y = math.cos(angle_y), math.sin(angle_y)
        x_new = x * cos_y + z * sin_y
        z_new = -x * sin_y + z * cos_y
        x, z = x_new, z_new
 
        # Rotation around Z-axis
        cos_z, sin_z = math.cos(angle_z), math.sin(angle_z)
        x_new = x * cos_z - y * sin_z
        y_new = x * sin_z + y * cos_z
        x, y = x_new, y_new
 
        return [x, y, z]
 
    def get_rotated_vertices(self):
        """
        Apply rotation to all vertices
        """
        angle = math.radians(self.rotation_angle)
        rotated = []
 
        for vertex in self.vertices:
            rotated_vertex = self.rotate_vertex(vertex, angle, angle, angle)
            rotated.append(rotated_vertex)
 
        return rotated
 
    def display_cube_info(self):
        """
        Display cube structure and current state
        """
        print("\n" + "="*60)
        print("IT2202 - Lab Exercise 1: 3D Wireframe Cube")
        print("="*60)
 
        # Display original vertices (as specified in lab manual)
        print("\nOriginal Vertices (Lab Manual Table):")
        print("Vertex | X  | Y  | Z ")
        print("-------|----|----|----")
        for i, vertex in enumerate(self.vertices):
            print("   {}   | {:2} | {:2} | {:2}".format(i, vertex[0], vertex[1], vertex[2]))
 
        # Display edges
        print("\nEdges (Connecting Vertex Pairs):")
        edge_names = ['A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L']
        for i, (v1, v2) in enumerate(self.edges):
            print("Edge {}: Vertex {} ↔ Vertex {}".format(edge_names[i], v1, v2))
 
        # Display current rotation
        rotated_vertices = self.get_rotated_vertices()
        print("\nCurrent Rotation Angle: {}°".format(self.rotation_angle))
        print("\nRotated Vertices (Current Frame):")
        print("Vertex |    X    |    Y    |    Z   ")
        print("-------|---------|---------|--------")
        for i, vertex in enumerate(rotated_vertices):
            print("   {}   | {:7.3f} | {:7.3f} | {:7.3f}".format(i, vertex[0], vertex[1], vertex[2]))
 
    def simple_projection(self, vertex):
        """
        Simple 2D projection for text visualization
        """
        x, y, z = vertex
        # Simple orthographic projection (ignore z for 2D display)
        screen_x = int(x * 10 + 20)  # Scale and center
        screen_y = int(-y * 5 + 10)   # Scale, flip Y, and center
        return screen_x, screen_y
 
    def draw_ascii_cube(self):
        """
        Draw a simple ASCII representation of the cube
        """
        print("\nASCII Cube Projection (Top View):")
        print("(Simulating pygame.display and OpenGL rendering)")
 
        # Create a simple grid
        grid = [[' ' for _ in range(40)] for _ in range(20)]
 
        rotated_vertices = self.get_rotated_vertices()
 
        # Mark vertices on the grid
        for i, vertex in enumerate(rotated_vertices):
            x, y = self.simple_projection(vertex)
            if 0 <= x < 40 and 0 <= y < 20:
                grid[y][x] = str(i)
 
        # Draw the grid
        for row in grid:
            print(''.join(row))
 
        print("\nNumbers 0-7 represent the cube vertices")
        print("This simulates what you would see in the OpenGL window")
 
def simulate_pygame_loop():
    """
    Step 11: Simulate the main pygame event loop
    """
    cube = Cube3D()
 
    print("Starting IT2202 Lab Exercise 1 Simulation...")
    print("(This simulates pygame.init() and OpenGL setup)")
    print("\nSimulating continuous rotation...")
    print("In real OpenGL: glRotatef(1, 1, 1, 1) would rotate 1° around vector (1,1,1)")
    print("\nPress Ctrl+C to stop the simulation")
 
    try:
        # Simulate the main loop (show 5 frames instead of infinite)
        for frame in range(5):
            print("\n{} FRAME {} {}".format("="*20, frame + 1, "="*20))
 
            # Step 16: Simulate glRotatef(1, 1, 1, 1)
            cube.rotation_angle += 15  # Increase by 15° each frame for visibility
 
            # Step 11: Simulate glClear() and drawing
            cube.display_cube_info()
            cube.draw_ascii_cube()
 
            # Step 11: Simulate pygame.time.wait(15)
            if frame < 4:  # Don't wait on last frame
                print("\n[Simulating pygame.time.wait(15)...]")
                time.sleep(1)  # Reduced delay for demo
 
        print("\n{}".format("="*60))
        print("Simulation complete!")
        print("In real OpenGL, this would show a smoothly rotating 3D wireframe cube")
        print("{}".format("="*60))
 
    except KeyboardInterrupt:
        print("\nSimulation stopped by user")
        print("(Simulates pygame.quit() when window is closed)")
 
def main():
    """
    Main function demonstrating all lab concepts
    """
    print("IT2202 - 03 Laboratory Exercise 1")
    print("Pygame and OpenGL Simulation for Online Compilers")
    print("="*60)
 
    # Show what would normally require package installation
    required_packages = ["pygame", "numpy", "PyOpenGL", "PyOpenGL_accelerate"]
    print("Required packages (not available in online compilers): {}".format(', '.join(required_packages)))
    print("Install locally with: py -m pip install {}".format(" ".join(required_packages)))
 
    # Demonstrate the lab concepts
    simulate_pygame_loop()
 
if __name__ == "__main__":
    main()