Point Cloud Library (PCL)
1.14.1-dev
|
PCL-LZF image format writer. More...
#include <pcl/io/lzf_image_io.h>
Public Member Functions | |
LZFImageWriter ()=default | |
Empty constructor. More... | |
virtual | ~LZFImageWriter ()=default |
Empty destructor. More... | |
virtual bool | write (const char *data, std::uint32_t width, std::uint32_t height, const std::string &filename)=0 |
Save an image into PCL-LZF format. More... | |
virtual bool | writeParameters (const CameraParameters ¶meters, const std::string &filename)=0 |
Write camera parameters to disk. More... | |
virtual bool | write (const char *data, std::uint32_t width, std::uint32_t height, const CameraParameters ¶meters, const std::string &filename_data, const std::string &filename_xml) |
Save an image and its camera parameters into PCL-LZF format. More... | |
bool | writeParameter (const double ¶meter, const std::string &tag, const std::string &filename) |
Write a single image/camera parameter to file, given an XML tag. More... | |
Protected Member Functions | |
bool | saveImageBlob (const char *data, std::size_t data_size, const std::string &filename) |
Save a compressed image array to disk. More... | |
std::uint32_t | compress (const char *input, std::uint32_t input_size, std::uint32_t width, std::uint32_t height, const std::string &image_type, char *output) |
Realtime LZF compression. More... | |
PCL-LZF image format writer.
The PCL-LZF image format is nothing else but a LZF-modified compression over an existing file type (e.g., PNG). However, in certain situations, like RGB data for example, an [RGBRGB...RGB] array will be first reordered into [RR...RGG...GBB...B] in order to ensure better compression.
The current list of compressors/decompressors include:
Please note that files found using the above mentioned extensions will be treated as such. Inherit from this class and overwrite the I/O methods if you plan to change this behavior.
The main advantage of using the PCL-LZF image I/O routines is a very good file size versus I/O speed ratio. Tests performed using LZF, Snappy, ZIP, GZ2, BZIP2, as well as PNG, JPEG, and TIFF compression have shown that the internal PCL LZF methods provide the best score for the types of applications PCL is suited for.
Definition at line 374 of file lzf_image_io.h.
|
default |
Empty constructor.
|
virtualdefault |
Empty destructor.
|
protected |
Realtime LZF compression.
[in] | input | the array to compress |
[in] | input_size | the size of the array to compress |
[in] | width | the with of the data array |
[in] | height | the height of the data array |
[in] | image_type | the type of the image to save. This should be an up to 16 characters string describing the data type. Examples are: "bayer8", "rgb24", "yuv422", "depth16". |
[out] | output | the compressed output array (must be pre-allocated!) |
|
protected |
Save a compressed image array to disk.
[in] | data | the data to save |
[in] | data_size | the size of the data |
[in] | filename | the file name to write the data to |
|
inlinevirtual |
Save an image and its camera parameters into PCL-LZF format.
[in] | data | the array holding the image |
[in] | width | the with of the data array |
[in] | height | the height of the data array |
[in] | parameters | the camera parameters |
[in] | filename_data | the file name to write the data to |
[in] | filename_xml | the file name to write the parameters to |
Definition at line 413 of file lzf_image_io.h.
References pcl::write().
|
pure virtual |
Save an image into PCL-LZF format.
Virtual.
[in] | data | the array holding the image |
[in] | width | the with of the data array |
[in] | height | the height of the data array |
[in] | filename | the file name to write |
Implemented in pcl::io::LZFBayer8ImageWriter, pcl::io::LZFYUV422ImageWriter, pcl::io::LZFRGB24ImageWriter, and pcl::io::LZFDepth16ImageWriter.
bool pcl::io::LZFImageWriter::writeParameter | ( | const double & | parameter, |
const std::string & | tag, | ||
const std::string & | filename | ||
) |
Write a single image/camera parameter to file, given an XML tag.
[in] | parameter | the value of the parameter to write |
[in] | tag | the value of the XML tag |
[in] | filename | the file name to write |
|
pure virtual |
Write camera parameters to disk.
Virtual.
[in] | parameters | the camera parameters |
[in] | filename | the file name to write |
Implemented in pcl::io::LZFRGB24ImageWriter, and pcl::io::LZFDepth16ImageWriter.