Auterion App SDK
Auterion SDK is a library that can be used by AuterionOS apps to communicate with the system.
object_detection_client.hpp
1 /****************************************************************************
2  *
3  * Copyright 2025 Auterion AG. All rights reserved.
4  *
5  * Redistribution and use in source and binary forms, with or without
6  * modification, are permitted provided that the following conditions are met:
7  *
8  * 1. Redistributions of source code must retain the above copyright notice, this
9  * list of conditions and the following disclaimer.
10  *
11  * 2. Redistributions in binary form must reproduce the above copyright notice,
12  * this list of conditions and the following disclaimer in the documentation
13  * and/or other materials provided with the distribution.
14  *
15  * 3. Neither the name of the copyright holder nor the names of its contributors
16  * may be used to endorse or promote products derived from this software without
17  * specific prior written permission.
18  *
19  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
20  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
21  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
22  * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
23  * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
24  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
25  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
26  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
27  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
28  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
29  * POSSIBILITY OF SUCH DAMAGE.
30  *
31  ****************************************************************************/
32 
33 #pragma once
34 
35 #include <auterion_sdk/object_detection/image_detections_2d.hpp>
36 #include <functional>
37 #include <memory>
38 #include <string>
39 
40 namespace auterion {
41 
42 class SDK;
43 
49 using Detections2DCallback = std::function<void(const ImageDetections2D& image_detections)>;
50 
55  public:
61  Detections2DSubscription(const std::shared_ptr<class Detections2DSubscriptionImpl>& impl);
62 
71  void onUpdate(Detections2DCallback callback);
72 
81  void subscribe(Detections2DCallback callback = nullptr);
82 
90 
96  bool isLastValid() const;
97 
98  private:
99  std::shared_ptr<class Detections2DSubscriptionImpl> _impl;
100 };
101 
143  public:
152  SDK& sdk, const std::string& detections_topic = "object_detection/detections_2d",
153  const std::string& enabled_topic = "object_detection/detections_2d_enabled");
154 
159 
160  // Make non-copyable and non-movable
162  ObjectDetectionClient& operator=(const ObjectDetectionClient&) = delete;
164  ObjectDetectionClient& operator=(ObjectDetectionClient&&) = delete;
165 
172 
179  ObjectDetectionClient& subscribeDetections2D(Detections2DCallback callback = nullptr) {
180  detections2D().subscribe(callback);
181  return *this;
182  }
183 
189 
195 
196  private:
197  class Impl;
198  std::shared_ptr<Impl> _impl;
199 };
200 
201 } // namespace auterion
A class for managing subscriptions to 2D object detections.
Definition: object_detection_client.hpp:54
Detections2DSubscription(const std::shared_ptr< class Detections2DSubscriptionImpl > &impl)
Construct a new Detections2DSubscription object.
void onUpdate(Detections2DCallback callback)
Registers a callback function to be called when new detections are received.
bool isLastValid() const
Checks if the last received detections are valid.
void subscribe(Detections2DCallback callback=nullptr)
Activates the subscription process and registers a callback function if provided.
ImageDetections2D last() const
Retrieves the last received detections.
Provides access to 2D object detections from the system.
Definition: object_detection_client.hpp:142
Detections2DSubscription & detections2D() const
Get the detections2D subscription.
void disableObjectDetection()
Publishes a message to disable the object detection service. The publisher will receive this message ...
void enableObjectDetection()
Publishes a message to enable the object detection service. The publisher will receive this message a...
virtual ~ObjectDetectionClient()
Destroy the Object Detection Client object.
ObjectDetectionClient & subscribeDetections2D(Detections2DCallback callback=nullptr)
Subscribe to 2D object detections.
Definition: object_detection_client.hpp:179
ObjectDetectionClient(SDK &sdk, const std::string &detections_topic="object_detection/detections_2d", const std::string &enabled_topic="object_detection/detections_2d_enabled")
Construct a new Object Detection Client object.
SDK execution class. All callbacks are called on the same thread.
Definition: auterion.hpp:47
Contains 2D detections for a specific image.
Definition: image_detections_2d.hpp:44