mirror of
https://github.com/blakeblackshear/frigate.git
synced 2024-11-21 19:07:46 +01:00
Use zoom space id in Onvif RelativeMove setup (#9859)
* use zoom space id in onvif relativemove setup * better handle cases when zooming is disabled
This commit is contained in:
parent
bad80a64ef
commit
616eb5f96a
@ -151,7 +151,10 @@ class OnvifController:
|
|||||||
|
|
||||||
# autoracking relative panning/tilting needs a relative zoom value set to 0
|
# autoracking relative panning/tilting needs a relative zoom value set to 0
|
||||||
# if camera supports relative movement
|
# if camera supports relative movement
|
||||||
if self.config.cameras[camera_name].onvif.autotracking.zooming:
|
if (
|
||||||
|
self.config.cameras[camera_name].onvif.autotracking.zooming
|
||||||
|
!= ZoomingModeEnum.disabled
|
||||||
|
):
|
||||||
zoom_space_id = next(
|
zoom_space_id = next(
|
||||||
(
|
(
|
||||||
i
|
i
|
||||||
@ -182,23 +185,21 @@ class OnvifController:
|
|||||||
try:
|
try:
|
||||||
if (
|
if (
|
||||||
self.config.cameras[camera_name].onvif.autotracking.zooming
|
self.config.cameras[camera_name].onvif.autotracking.zooming
|
||||||
== ZoomingModeEnum.relative
|
!= ZoomingModeEnum.disabled
|
||||||
):
|
):
|
||||||
if zoom_space_id is not None:
|
if zoom_space_id is not None:
|
||||||
move_request.Translation.Zoom.space = ptz_config["Spaces"][
|
move_request.Translation.Zoom.space = ptz_config["Spaces"][
|
||||||
"RelativeZoomTranslationSpace"
|
"RelativeZoomTranslationSpace"
|
||||||
][0]["URI"]
|
][zoom_space_id]["URI"]
|
||||||
|
else:
|
||||||
|
move_request.Translation.Zoom = []
|
||||||
except Exception:
|
except Exception:
|
||||||
if (
|
self.config.cameras[
|
||||||
self.config.cameras[camera_name].onvif.autotracking.zooming
|
camera_name
|
||||||
== ZoomingModeEnum.relative
|
].onvif.autotracking.zooming = ZoomingModeEnum.disabled
|
||||||
):
|
logger.warning(
|
||||||
self.config.cameras[
|
f"Disabling autotracking zooming for {camera_name}: Relative zoom not supported"
|
||||||
camera_name
|
)
|
||||||
].onvif.autotracking.zooming = ZoomingModeEnum.disabled
|
|
||||||
logger.warning(
|
|
||||||
f"Disabling autotracking zooming for {camera_name}: Relative zoom not supported"
|
|
||||||
)
|
|
||||||
|
|
||||||
if move_request.Speed is None:
|
if move_request.Speed is None:
|
||||||
move_request.Speed = configs.DefaultPTZSpeed if configs else None
|
move_request.Speed = configs.DefaultPTZSpeed if configs else None
|
||||||
@ -387,7 +388,11 @@ class OnvifController:
|
|||||||
move_request.Translation.PanTilt.x = pan
|
move_request.Translation.PanTilt.x = pan
|
||||||
move_request.Translation.PanTilt.y = tilt
|
move_request.Translation.PanTilt.y = tilt
|
||||||
|
|
||||||
if "zoom-r" in self.cams[camera_name]["features"]:
|
if (
|
||||||
|
"zoom-r" in self.cams[camera_name]["features"]
|
||||||
|
and self.config.cameras[camera_name].onvif.autotracking.zooming
|
||||||
|
== ZoomingModeEnum.relative
|
||||||
|
):
|
||||||
move_request.Speed = {
|
move_request.Speed = {
|
||||||
"PanTilt": {
|
"PanTilt": {
|
||||||
"x": speed,
|
"x": speed,
|
||||||
@ -403,7 +408,11 @@ class OnvifController:
|
|||||||
move_request.Translation.PanTilt.x = 0
|
move_request.Translation.PanTilt.x = 0
|
||||||
move_request.Translation.PanTilt.y = 0
|
move_request.Translation.PanTilt.y = 0
|
||||||
|
|
||||||
if "zoom-r" in self.cams[camera_name]["features"]:
|
if (
|
||||||
|
"zoom-r" in self.cams[camera_name]["features"]
|
||||||
|
and self.config.cameras[camera_name].onvif.autotracking.zooming
|
||||||
|
== ZoomingModeEnum.relative
|
||||||
|
):
|
||||||
move_request.Translation.Zoom.x = 0
|
move_request.Translation.Zoom.x = 0
|
||||||
|
|
||||||
self.cams[camera_name]["active"] = False
|
self.cams[camera_name]["active"] = False
|
||||||
|
Loading…
Reference in New Issue
Block a user