dataunpacker.h
Go to the documentation of this file.
1 /*
2  * Slamtec LIDAR SDK
3  *
4  * Copyright (c) 2014 - 2023 Shanghai Slamtec Co., Ltd.
5  * http://www.slamtec.com
6  *
7  */
8 
9  /*
10  * Sample Data Unpacker System
11  *
12  */
13 
14  /*
15  * Redistribution and use in source and binary forms, with or without
16  * modification, are permitted provided that the following conditions are met:
17  *
18  * 1. Redistributions of source code must retain the above copyright notice,
19  * this list of conditions and the following disclaimer.
20  *
21  * 2. Redistributions in binary form must reproduce the above copyright notice,
22  * this list of conditions and the following disclaimer in the documentation
23  * and/or other materials provided with the distribution.
24  *
25  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
26  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
27  * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
28  * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR
29  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
30  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
31  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
32  * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
33  * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
34  * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
35  * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
36  *
37  */
38 
39 
40 #pragma once
41 
42 #include "dataupacker_namespace.h"
43 
45 
46 
48 {
49 
50 
51 public:
52  virtual void onHQNodeScanResetReq() = 0;
53  virtual void onHQNodeDecoded(_u64 timestamp_uS, const rplidar_response_measurement_node_hq_t* node) = 0;
54  virtual void onCustomSampleDataDecoded(_u8 ansType, _u32 customCode, const void* data, size_t size) {}
55 
56  virtual void onDecodingError(int errMsg, _u8 ansType, const void* payload, size_t size) {}
57 };
58 
60 {
61 public:
62  enum {
65  };
66 
71 
72  };
73 
74  virtual ~LIDARSampleDataUnpacker();
77 
78  virtual void updateUnpackerContext(UnpackerContextType type, const void* data, size_t size) = 0;
79 
80  virtual void enable() = 0;
81  virtual void disable() = 0;
82 
83  virtual bool onSampleData(_u8 ansType, const void* buffer, size_t size) = 0;
84  virtual void reset() = 0;
85  virtual void clearCache() = 0;
86 
87 protected:
90 
91 };
92 
sl_lidar_response_measurement_node_hq_t
Definition: sl_lidar_cmd.h:272
LIDARSampleDataUnpacker::onSampleData
virtual bool onSampleData(_u8 ansType, const void *buffer, size_t size)=0
BEGIN_DATAUNPACKER_NS
#define BEGIN_DATAUNPACKER_NS()
Definition: dataupacker_namespace.h:4
type
sl_u32 type
Definition: sl_lidar_cmd.h:2
_u8
uint8_t _u8
Definition: rptypes.h:63
dataupacker_namespace.h
LIDARSampleDataUnpacker::disable
virtual void disable()=0
size
sl_u8 size
Definition: sl_lidar_protocol.h:4
LIDARSampleDataListener::onCustomSampleDataDecoded
virtual void onCustomSampleDataDecoded(_u8 ansType, _u32 customCode, const void *data, size_t size)
Definition: dataunpacker.h:54
LIDARSampleDataUnpacker::~LIDARSampleDataUnpacker
virtual ~LIDARSampleDataUnpacker()
Definition: dataunpacker.cpp:248
LIDARSampleDataUnpacker::UNPACKER_CONTEXT_TYPE_TRIANGULATION_OPTICAL_FACTOR
@ UNPACKER_CONTEXT_TYPE_TRIANGULATION_OPTICAL_FACTOR
Definition: dataunpacker.h:70
LIDARSampleDataListener::onDecodingError
virtual void onDecodingError(int errMsg, _u8 ansType, const void *payload, size_t size)
Definition: dataunpacker.h:56
LIDARSampleDataUnpacker::UNPACKER_CONTEXT_TYPE_LIDAR_UNKNOWN
@ UNPACKER_CONTEXT_TYPE_LIDAR_UNKNOWN
Definition: dataunpacker.h:68
LIDARSampleDataUnpacker::ERR_EVENT_ON_EXP_CHECKSUM_ERR
@ ERR_EVENT_ON_EXP_CHECKSUM_ERR
Definition: dataunpacker.h:64
payload
sl_u8 payload[0]
Definition: sl_lidar_cmd.h:3
LIDARSampleDataUnpacker::updateUnpackerContext
virtual void updateUnpackerContext(UnpackerContextType type, const void *data, size_t size)=0
LIDARSampleDataUnpacker::UNPACKER_CONTEXT_TYPE_LIDAR_TIMING
@ UNPACKER_CONTEXT_TYPE_LIDAR_TIMING
Definition: dataunpacker.h:69
LIDARSampleDataUnpacker
Definition: dataunpacker.h:59
LIDARSampleDataUnpacker::_listener
LIDARSampleDataListener & _listener
Definition: dataunpacker.h:89
LIDARSampleDataUnpacker::ERR_EVENT_ON_EXP_ENCODER_RESET
@ ERR_EVENT_ON_EXP_ENCODER_RESET
Definition: dataunpacker.h:63
LIDARSampleDataUnpacker::clearCache
virtual void clearCache()=0
LIDARSampleDataUnpacker::UnpackerContextType
UnpackerContextType
Definition: dataunpacker.h:67
LIDARSampleDataListener
Definition: dataunpacker.h:47
LIDARSampleDataUnpacker::enable
virtual void enable()=0
_u64
uint64_t _u64
Definition: rptypes.h:72
LIDARSampleDataUnpacker::LIDARSampleDataUnpacker
LIDARSampleDataUnpacker(LIDARSampleDataListener &)
Definition: dataunpacker.cpp:252
LIDARSampleDataUnpacker::reset
virtual void reset()=0
data
sl_u8 data[0]
Definition: sl_lidar_protocol.h:5
END_DATAUNPACKER_NS
#define END_DATAUNPACKER_NS()
Definition: dataupacker_namespace.h:5
_u32
uint32_t _u32
Definition: rptypes.h:69
LIDARSampleDataUnpacker::ReleaseInstance
static void ReleaseInstance(LIDARSampleDataUnpacker *)
Definition: dataunpacker.cpp:244
LIDARSampleDataUnpacker::CreateInstance
static LIDARSampleDataUnpacker * CreateInstance(LIDARSampleDataListener &listener)
Definition: dataunpacker.cpp:225


rplidar_ros
Author(s):
autogenerated on Fri Aug 2 2024 08:42:13