-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathwrapper.py
More file actions
68 lines (61 loc) · 2.45 KB
/
Copy pathwrapper.py
File metadata and controls
68 lines (61 loc) · 2.45 KB
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
import airsim
import os
import logging
import math
logger = logging.getLogger(__name__)
class AirSimWrapper:
def __init__(self):
ip = os.getenv('PX4_SIM_HOST_ADDR', '192.168.64.1') # Change IP if necessary
port = int(os.getenv('PX4_SIM_PORT', '41451'))
logger.info(f"Connecting to AirSim server at {ip}:{port}")
self.client = airsim.VehicleClient(ip=ip, port=port)
try:
self.client.confirmConnection()
logger.info("Connection to AirSim successful!")
except Exception as e:
logger.error(f"Failed to connect to AirSim: {e}")
raise
def get_camera_pose(self):
try:
return self.client.simGetVehiclePose()
except Exception as e:
logger.error(f"Error getting camera pose: {e}")
return None
def set_camera_pose(self, pose):
try:
self.client.simSetVehiclePose(pose, True)
except Exception as e:
logger.error(f"Error setting camera pose: {e}")
def list_scene_objects(self):
try:
return self.client.simListSceneObjects()
except Exception as e:
logger.error(f"Error listing scene objects: {e}")
return []
def get_position(self, object_name):
try:
object_names_ue = self.client.simListSceneObjects(object_name + ".*")
if not object_names_ue:
logger.warning(f"Object '{object_name}' not found in the scene.")
return None
pose = self.client.simGetObjectPose(object_names_ue[0])
return [pose.position.x_val, pose.position.y_val, pose.position.z_val]
except Exception as e:
logger.error(f"Error getting position of {object_name}: {e}")
return None
def capture_image(self, image_filename):
try:
responses = self.client.simGetImages([
airsim.ImageRequest("0", airsim.ImageType.Scene, False, False)
])
if responses:
image_data = responses[0].image_data_uint8
airsim.write_file(image_filename, image_data)
logger.info(f"Image saved as {image_filename}")
return image_filename
else:
logger.warning("No image captured.")
return None
except Exception as e:
logger.error(f"Error capturing image: {e}")
return None