-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathSpawngoal.py
78 lines (65 loc) · 2.52 KB
/
Spawngoal.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
import rclpy
from geometry_msgs.msg import Pose, Point, Quaternion
from gazebo_msgs.srv import SpawnEntity, DeleteEntity
GETGOALTHRESHOLD = 0.4
def spawn_circle(position):
# Spawn a circle at the given position
node = rclpy.create_node('spawn_circle_node')
spawn_entity = node.create_client(SpawnEntity, '/spawn_entity')
circle_sdf = """
<?xml version="1.0" ?>
<sdf version='1.6'>
<model name='circle'>
<pose frame=''>0 0 0 0 -0 0</pose>
<link name='link'>
<visual name='visual'>
<pose frame=''>0 0 0.0005 0 -0 0</pose>
<geometry>
<cylinder>
<radius>0.6</radius>
<length>0.001</length>
</cylinder>
</geometry>
<material>
<script>
<uri>file://media/materials/scripts/gazebo.material</uri>
<name>Gazebo/Grey</name>
</script>
<ambient>1 0 0 1</ambient>
</material>
</visual>
<pose frame=''>0 0 0 0 -0 0</pose>
</link>
<static>1</static>
</model>
</sdf>
"""
# .format(radius = GETGOALTHRESHOLD) # the SDF string for the circle model
entity_name = 'circle'
req = SpawnEntity.Request()
req.xml = circle_sdf
req.initial_pose.position = Point(x=position[0], y=position[1], z=0.0)
req.reference_frame = 'world'
future = spawn_entity.call_async(req)
rclpy.spin_until_future_complete(node, future)
pidnode(node)
# if future.result() is not None:
# node.get_logger().info(f"Successfully spawned {entity_name} at {position}")
# else:
# node.get_logger().error(f"Failed to spawn {entity_name}: {future.exception()}")
def delete_circle():
# Delete the entity
node = rclpy.create_node('delete_circle_node')
delete_entity = node.create_client(DeleteEntity, '/delete_entity')
entity_name = 'circle'
req = DeleteEntity.Request()
req.name = entity_name
future = delete_entity.call_async(req)
rclpy.spin_until_future_complete(node, future)
pidnode(node)
# if future.result() is not None:
# node.get_logger().info(f"Successfully deleted {entity_name}")
# else:
# node.get_logger().error(f"Failed to delete {entity_name}: {future.exception()}")
def pidnode(node):
node.destroy_node()