Skip to content

Commit

Permalink
fence: add options to change circle radii
Browse files Browse the repository at this point in the history
  • Loading branch information
peterbarker authored and tridge committed Feb 28, 2024
1 parent dce61d6 commit 2578dbb
Showing 1 changed file with 53 additions and 1 deletion.
54 changes: 53 additions & 1 deletion MAVProxy/modules/mavproxy_fence.py
Original file line number Diff line number Diff line change
Expand Up @@ -288,7 +288,7 @@ def cmd_addcircle(self, args):
if not self.check_have_list():
return
if len(args) < 2:
print("Need 2 arguments")
print("Usage: fence setcircle inclusion|exclusion RADIUS")
return
t = args[0]
radius = float(args[1])
Expand Down Expand Up @@ -445,6 +445,18 @@ def removereturnpoint(self, seq):
self.wploader.last_change = time.time()
self.send_all_items()

def cmd_setcircleradius(self, args):
if len(args) < 1:
print("fence setcircleradius INDEX RADIUS")
return

if len(args) < 2:
# this one will use the click position:
self.setcircleradius(int(args[0]))
return

self.setcircleradius(int(args[0]), radius=float(args[1]))

def cmd_movecircle(self, args):
self.movecircle(int(args[0]))

Expand Down Expand Up @@ -499,6 +511,45 @@ def movecircle(self, seq):

self.send_single_waypoint(moving_item.seq)

def setcircleradius(self, seq, radius=None):
'''change radius of circle at seq to radius
'''
if not self.check_have_list():
return

item = self.wploader.item(seq)
if item is None:
print("No item %s" % str(seq))
return

if not self.is_circle_item(item):
print("Item %u is not a circle" % seq)
return

if radius is None:
# calculate radius from clock position:
latlon = self.mpstate.click_location
if latlon is None:
print("No click position available")
return
item_x = item.x
item_y = item.y
if item.get_type() == 'MISSION_ITEM_INT':
item_x *= 1e-7
item_y *= 1e-7
radius = mavextra.distance_lat_lon(latlon[0], latlon[1], item_x, item_y)
elif radius <= 0:
print("radius must be positive")
return

changing_item = self.wploader.item(seq)
changing_item.param1 = radius

self.wploader.set(changing_item, changing_item.seq)
self.wploader.last_change = time.time()

self.send_single_waypoint(changing_item.seq)

def is_circle_item(self, item):
return item.command in [
mavutil.mavlink.MAV_CMD_NAV_FENCE_CIRCLE_EXCLUSION,
Expand Down Expand Up @@ -719,6 +770,7 @@ def commands(self):
ret.update({
'addcircle': (self.cmd_addcircle, ["<inclusion|inc|exclusion|exc>", "RADIUS"]),
'movecircle': (self.cmd_movecircle, []),
'setcircleradius': (self.cmd_setcircleradius, ["seq radius"]),
'addpoly': (self.cmd_addpoly, ["<inclusion|inc|exclusion|exc>", "<radius>" "<pointcount>", "<rotation>"]),
'movepolypoint': (self.cmd_movepolypoint, ["POLY_FIRSTPOINT", "POINT_OFFSET"]),
'addreturnpoint': (self.cmd_addreturnpoint, []),
Expand Down

0 comments on commit 2578dbb

Please # to comment.