import bpy
import math
import random
from mathutils import Vector

# Constants for camera orbit constraints
DISTANCE = 4.0  # Distance from target to camera

# X angle constraints (vertical tilt)
X_MIN_ANGLE = math.radians(45)
X_MAX_ANGLE = math.radians(120)

# Y angle constraints (elevation)
Y_MIN_ANGLE = math.radians(-50)
Y_MAX_ANGLE = math.radians(50)

# Z angle constraints (horizontal rotation)
Z_MIN_ANGLE = math.radians(-30)
Z_MAX_ANGLE = math.radians(30)


def randomize_camera_position():
    # Get the target object and camera
    target_obj = bpy.data.objects["Target"]
    camera = bpy.data.objects["Camera"]

    # Generate random angles within constraints
    x_angle = random.uniform(X_MIN_ANGLE, X_MAX_ANGLE)
    y_angle = random.uniform(Y_MIN_ANGLE, Y_MAX_ANGLE)
    z_angle = random.uniform(Z_MIN_ANGLE, Z_MAX_ANGLE)

    # Convert spherical coordinates to cartesian
    x = DISTANCE * math.sin(y_angle) * math.cos(z_angle)
    y = DISTANCE * math.sin(y_angle) * math.sin(z_angle)
    z = DISTANCE * math.cos(y_angle)

    # Apply x_angle rotation (tilt)
    y_rotated = y * math.cos(x_angle) - z * math.sin(x_angle)
    z_rotated = y * math.sin(x_angle) + z * math.cos(x_angle)

    # Get target position
    target_pos = target_obj.location

    # Set camera position
    camera.location = Vector(
        (target_pos.x + x, target_pos.y + y_rotated, target_pos.z + z_rotated)
    )

    # Make camera look at target
    direction = target_obj.location - camera.location
    rot_quat = direction.to_track_quat("-Z", "Y")
    camera.rotation_euler = rot_quat.to_euler()


# Run the randomization when script is executed
randomize_camera_position()
