Auterion App SDK
Auterion SDK is a library that can be used by AuterionOS apps to communicate with the system.
Loading...
Searching...
No Matches
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
40namespace auterion {
41
42class SDK;
43
49using 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.
ObjectDetectionClient & subscribeDetections2D(Detections2DCallback callback=nullptr)
Subscribe to 2D object detections.
Definition object_detection_client.hpp:179
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(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:97
Contains 2D detections for a specific image.
Definition image_detections_2d.hpp:44