42 lines
1.2 KiB
Python
42 lines
1.2 KiB
Python
#!/usr/bin/env python3
|
|
"""Test that timers work correctly with --exec"""
|
|
import mcrfpy
|
|
from mcrfpy import automation
|
|
|
|
print("Setting up timer test...")
|
|
|
|
# Create a scene
|
|
mcrfpy.createScene("timer_works")
|
|
mcrfpy.setScene("timer_works")
|
|
ui = mcrfpy.sceneUI("timer_works")
|
|
|
|
# Add visible content
|
|
frame = mcrfpy.Frame(100, 100, 300, 200,
|
|
fill_color=mcrfpy.Color(255, 0, 0),
|
|
outline_color=mcrfpy.Color(255, 255, 255),
|
|
outline=3.0)
|
|
ui.append(frame)
|
|
|
|
caption = mcrfpy.Caption(mcrfpy.Vector(150, 150),
|
|
text="TIMER TEST SUCCESS",
|
|
fill_color=mcrfpy.Color(255, 255, 255))
|
|
caption.size = 24
|
|
ui.append(caption)
|
|
|
|
# Timer callback with correct signature
|
|
def timer_callback(runtime):
|
|
print(f"\n✓ Timer fired successfully at runtime: {runtime}")
|
|
|
|
# Take screenshot
|
|
filename = f"timer_success_{int(runtime)}.png"
|
|
result = automation.screenshot(filename)
|
|
print(f"Screenshot saved: {filename} - Result: {result}")
|
|
|
|
# Cancel timer and exit
|
|
mcrfpy.delTimer("success_timer")
|
|
print("Exiting...")
|
|
mcrfpy.exit()
|
|
|
|
# Set timer
|
|
mcrfpy.setTimer("success_timer", timer_callback, 1000)
|
|
print("Timer set for 1 second. Game loop starting...") |