mirror of
https://github.com/opencv/opencv.git
synced 2025-01-18 06:03:15 +08:00
change code
to snippet
and do some cleaning.
- use `@snippet` instead of `@code` in docs. - remove some functions that were not used.
This commit is contained in:
parent
8a65e73bfd
commit
08911cbfae
@ -1978,14 +1978,11 @@ The function opens file storage for reading or writing data. In the latter case,
|
|||||||
created or an existing file is rewritten. The type of the read or written file is determined by the
|
created or an existing file is rewritten. The type of the read or written file is determined by the
|
||||||
filename extension: .xml for XML and .yml or .yaml for YAML.
|
filename extension: .xml for XML and .yml or .yaml for YAML.
|
||||||
|
|
||||||
At the same time, it also supports adding parameters like "example.xml?base64".
|
At the same time, it also supports adding parameters like "example.xml?base64". The three ways
|
||||||
@code
|
are the same:
|
||||||
CvFileStorage* fs = cvOpenFileStorage( "example.yml?base64", 0, CV_STORAGE_WRITE );
|
@snippet samples/cpp/filestorage_base64.cpp suffix_in_file_name
|
||||||
@endcode
|
@snippet samples/cpp/filestorage_base64.cpp flag_write_base64
|
||||||
it's exactly the same as
|
@snippet samples/cpp/filestorage_base64.cpp flag_write_and_flag_base64
|
||||||
@code
|
|
||||||
CvFileStorage* fs = cvOpenFileStorage( "example.yml", 0, CV_STORAGE_WRITE_BASE64 );
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
The function returns a pointer to the CvFileStorage structure.
|
The function returns a pointer to the CvFileStorage structure.
|
||||||
If the file cannot be opened then the function returns NULL.
|
If the file cannot be opened then the function returns NULL.
|
||||||
@ -2209,27 +2206,9 @@ in plain text.
|
|||||||
This function can only be used to write a sequence with a type "binary".
|
This function can only be used to write a sequence with a type "binary".
|
||||||
|
|
||||||
Consider the following two examples where their output is the same:
|
Consider the following two examples where their output is the same:
|
||||||
@code
|
@snippet samples/cpp/filestorage_base64.cpp without_base64_flag
|
||||||
std::vector<int> rawdata(10, 0x00010203);
|
|
||||||
// without the flag CV_STORAGE_WRITE_BASE64.
|
|
||||||
CvFileStorage* fs = cvOpenFileStorage( "example.yml", 0, CV_STORAGE_WRITE );
|
|
||||||
// both CV_NODE_SEQ and "binary" are necessary.
|
|
||||||
cvStartWriteStruct(fs, "rawdata", CV_NODE_SEQ | CV_NODE_FLOW, "binary");
|
|
||||||
cvWriteRawDataBase64(fs, rawdata.data(), rawdata.size(), "i");
|
|
||||||
cvEndWriteStruct(fs);
|
|
||||||
cvReleaseFileStorage( &fs );
|
|
||||||
@endcode
|
|
||||||
and
|
and
|
||||||
@code
|
@snippet samples/cpp/filestorage_base64.cpp with_write_base64_flag
|
||||||
std::vector<int> rawdata(10, 0x00010203);
|
|
||||||
// with the flag CV_STORAGE_WRITE_BASE64.
|
|
||||||
CvFileStorage* fs = cvOpenFileStorage( "example.yml", 0, CV_STORAGE_WRITE_BASE64);
|
|
||||||
// parameter, typename "binary" could be omitted.
|
|
||||||
cvStartWriteStruct(fs, "rawdata", CV_NODE_SEQ | CV_NODE_FLOW);
|
|
||||||
cvWriteRawData(fs, rawdata.data(), rawdata.size(), "i");
|
|
||||||
cvEndWriteStruct(fs);
|
|
||||||
cvReleaseFileStorage( &fs );
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
@param fs File storage
|
@param fs File storage
|
||||||
@param src Pointer to the written array
|
@param src Pointer to the written array
|
||||||
|
@ -308,7 +308,6 @@ namespace base64
|
|||||||
template<> inline size_t binary_to(uchar const * cur, float & val);
|
template<> inline size_t binary_to(uchar const * cur, float & val);
|
||||||
template<typename _primitive_t> inline size_t binary_to(uchar const * cur, uchar * val);
|
template<typename _primitive_t> inline size_t binary_to(uchar const * cur, uchar * val);
|
||||||
|
|
||||||
class MatToBinaryConvertor;
|
|
||||||
class RawDataToBinaryConvertor;
|
class RawDataToBinaryConvertor;
|
||||||
|
|
||||||
class BinaryToCvSeqConvertor;
|
class BinaryToCvSeqConvertor;
|
||||||
@ -363,8 +362,6 @@ namespace base64
|
|||||||
/* sample */
|
/* sample */
|
||||||
|
|
||||||
void cvWriteRawDataBase64(::CvFileStorage* fs, const void* _data, int len, const char* dt);
|
void cvWriteRawDataBase64(::CvFileStorage* fs, const void* _data, int len, const char* dt);
|
||||||
|
|
||||||
void cvWriteMat_Base64(::CvFileStorage * fs, const char * name, ::cv::Mat const & mat);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -2306,7 +2303,7 @@ static char* icvXMLParseBase64(CvFileStorage* fs, char* ptr, CvFileNode * node)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* get all Base64 data */
|
/* get all Base64 data */
|
||||||
std::string base64_buffer;
|
std::string base64_buffer; // not an efficient way.
|
||||||
base64_buffer.reserve( 16U * 1024U * 1024U );
|
base64_buffer.reserve( 16U * 1024U * 1024U );
|
||||||
while( beg < end )
|
while( beg < end )
|
||||||
{
|
{
|
||||||
@ -3715,13 +3712,13 @@ icvCalcStructSize( const char* dt, int initial_size )
|
|||||||
for ( const char * type = dt; *type != '\0'; type++ ) {
|
for ( const char * type = dt; *type != '\0'; type++ ) {
|
||||||
switch ( *type )
|
switch ( *type )
|
||||||
{
|
{
|
||||||
case 'u': { if (elem_max_size < sizeof(uchar)) elem_max_size = sizeof(uchar); break; }
|
case 'u': { elem_max_size = std::max( elem_max_size, sizeof(uchar ) ); break; }
|
||||||
case 'c': { if (elem_max_size < sizeof(schar)) elem_max_size = sizeof(schar); break; }
|
case 'c': { elem_max_size = std::max( elem_max_size, sizeof(schar ) ); break; }
|
||||||
case 'w': { if (elem_max_size < sizeof(ushort)) elem_max_size = sizeof(ushort); break; }
|
case 'w': { elem_max_size = std::max( elem_max_size, sizeof(ushort) ); break; }
|
||||||
case 's': { if (elem_max_size < sizeof(short)) elem_max_size = sizeof(short); break; }
|
case 's': { elem_max_size = std::max( elem_max_size, sizeof(short ) ); break; }
|
||||||
case 'i': { if (elem_max_size < sizeof(int)) elem_max_size = sizeof(int); break; }
|
case 'i': { elem_max_size = std::max( elem_max_size, sizeof(int ) ); break; }
|
||||||
case 'f': { if (elem_max_size < sizeof(float)) elem_max_size = sizeof(float); break; }
|
case 'f': { elem_max_size = std::max( elem_max_size, sizeof(float ) ); break; }
|
||||||
case 'd': { if (elem_max_size < sizeof(double)) elem_max_size = sizeof(double); break; }
|
case 'd': { elem_max_size = std::max( elem_max_size, sizeof(double) ); break; }
|
||||||
default: break;
|
default: break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -6869,111 +6866,6 @@ private:
|
|||||||
uchar * src_end;
|
uchar * src_end;
|
||||||
};
|
};
|
||||||
|
|
||||||
class base64::MatToBinaryConvertor
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
|
|
||||||
explicit MatToBinaryConvertor(const cv::Mat & src)
|
|
||||||
: y (0)
|
|
||||||
, y_max(0)
|
|
||||||
, x(0)
|
|
||||||
, x_max(0)
|
|
||||||
{
|
|
||||||
/* make sure each mat `mat.dims == 2` */
|
|
||||||
if (src.dims > 2) {
|
|
||||||
const cv::Mat * arrays[] = { &src, 0 };
|
|
||||||
cv::Mat plane;
|
|
||||||
cv::NAryMatIterator it(arrays, &plane, 1);
|
|
||||||
|
|
||||||
CV_Assert(it.nplanes > 0U); /* make sure mats not empty */
|
|
||||||
mats.reserve(it.nplanes);
|
|
||||||
for (size_t i = 0U; i < it.nplanes; ++i, ++it)
|
|
||||||
mats.push_back(*it.planes);
|
|
||||||
} else {
|
|
||||||
mats.push_back(src);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* set all to beginning */
|
|
||||||
mat_iter = mats.begin();
|
|
||||||
y_max = (mat_iter)->rows;
|
|
||||||
x_max = (mat_iter)->cols * (mat_iter)->elemSize();
|
|
||||||
row_begin = (mat_iter)->ptr(0);
|
|
||||||
step = (mat_iter)->elemSize1();
|
|
||||||
|
|
||||||
/* choose a function */
|
|
||||||
switch ((mat_iter)->depth())
|
|
||||||
{
|
|
||||||
case CV_8U :
|
|
||||||
case CV_8S : { to_binary_func = to_binary<uchar> ; break; }
|
|
||||||
case CV_16U:
|
|
||||||
case CV_16S: { to_binary_func = to_binary<ushort>; break; }
|
|
||||||
case CV_32S: { to_binary_func = to_binary<uint> ; break; }
|
|
||||||
case CV_32F: { to_binary_func = to_binary<float> ; break; }
|
|
||||||
case CV_64F: { to_binary_func = to_binary<double>; break; }
|
|
||||||
case CV_USRTYPE1:
|
|
||||||
default: { CV_Assert(!"mat type is invalid"); break; }
|
|
||||||
};
|
|
||||||
|
|
||||||
/* check if empty */
|
|
||||||
if (mats.empty() || mats.front().empty() || mats.front().data == 0) {
|
|
||||||
mat_iter = mats.end();
|
|
||||||
CV_Assert(!(*this));
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
inline MatToBinaryConvertor & operator >> (uchar * & dst)
|
|
||||||
{
|
|
||||||
CV_DbgAssert(*this);
|
|
||||||
|
|
||||||
/* [1]copy to dst */
|
|
||||||
dst += to_binary_func(row_begin + x, dst);
|
|
||||||
|
|
||||||
/* [2]move to next */
|
|
||||||
x += step;
|
|
||||||
if (x >= x_max) {
|
|
||||||
/* when x arrive end, reset x and increase y */
|
|
||||||
x = 0U;
|
|
||||||
++ y;
|
|
||||||
if (y >= y_max) {
|
|
||||||
/* when y arrive end, reset y and increase iter */
|
|
||||||
y = 0U;
|
|
||||||
++ mat_iter;
|
|
||||||
if (mat_iter == mats.end()) {
|
|
||||||
;/* when iter arrive end, all done */
|
|
||||||
} else {
|
|
||||||
/* usually x_max and y_max won't change */
|
|
||||||
y_max = (mat_iter)->rows;
|
|
||||||
x_max = (mat_iter)->cols * (mat_iter)->elemSize();
|
|
||||||
row_begin = (mat_iter)->ptr(static_cast<int>(y));
|
|
||||||
}
|
|
||||||
} else
|
|
||||||
row_begin = (mat_iter)->ptr(static_cast<int>(y));
|
|
||||||
}
|
|
||||||
|
|
||||||
return *this;
|
|
||||||
}
|
|
||||||
|
|
||||||
inline operator bool() const
|
|
||||||
{
|
|
||||||
return mat_iter != mats.end();
|
|
||||||
}
|
|
||||||
|
|
||||||
private:
|
|
||||||
|
|
||||||
size_t y;
|
|
||||||
size_t y_max;
|
|
||||||
size_t x;
|
|
||||||
size_t x_max;
|
|
||||||
std::vector<cv::Mat>::iterator mat_iter;
|
|
||||||
std::vector<cv::Mat> mats;
|
|
||||||
|
|
||||||
size_t step;
|
|
||||||
const uchar * row_begin;
|
|
||||||
|
|
||||||
typedef size_t(*to_binary_t)(const uchar *, uchar *);
|
|
||||||
to_binary_t to_binary_func;
|
|
||||||
};
|
|
||||||
|
|
||||||
class base64::RawDataToBinaryConvertor
|
class base64::RawDataToBinaryConvertor
|
||||||
{
|
{
|
||||||
@ -7356,41 +7248,6 @@ void base64::cvWriteRawDataBase64(::CvFileStorage* fs, const void* _data, int le
|
|||||||
fs->base64_writer->write(_data, len, dt);
|
fs->base64_writer->write(_data, len, dt);
|
||||||
}
|
}
|
||||||
|
|
||||||
void base64::cvWriteMat_Base64(::CvFileStorage * fs, const char * name, ::cv::Mat const & mat)
|
|
||||||
{
|
|
||||||
char dt[4];
|
|
||||||
::icvEncodeFormat(CV_MAT_TYPE(mat.type()), dt);
|
|
||||||
|
|
||||||
{ /* [1]output other attr */
|
|
||||||
|
|
||||||
if (mat.dims <= 2) {
|
|
||||||
::cvStartWriteStruct(fs, name, CV_NODE_MAP, CV_TYPE_NAME_MAT);
|
|
||||||
|
|
||||||
::cvWriteInt(fs, "rows", mat.rows );
|
|
||||||
::cvWriteInt(fs, "cols", mat.cols );
|
|
||||||
} else {
|
|
||||||
::cvStartWriteStruct(fs, name, CV_NODE_MAP, CV_TYPE_NAME_MATND);
|
|
||||||
|
|
||||||
::cvStartWriteStruct(fs, "sizes", CV_NODE_SEQ | CV_NODE_FLOW);
|
|
||||||
::cvWriteRawData(fs, mat.size.p, mat.dims, "i");
|
|
||||||
::cvEndWriteStruct(fs);
|
|
||||||
}
|
|
||||||
::cvWriteString(fs, "dt", ::icvEncodeFormat(CV_MAT_TYPE(mat.type()), dt ), 0 );
|
|
||||||
}
|
|
||||||
|
|
||||||
{ /* [2]deal with matrix's data */
|
|
||||||
MatToBinaryConvertor convertor(mat);
|
|
||||||
|
|
||||||
::cvStartWriteStruct(fs, "data", CV_NODE_SEQ, "binary");
|
|
||||||
fs->base64_writer->write(convertor, dt);
|
|
||||||
::cvEndWriteStruct(fs);
|
|
||||||
}
|
|
||||||
|
|
||||||
{ /* [3]output end */
|
|
||||||
::cvEndWriteStruct(fs);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Interface
|
* Interface
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
71
samples/cpp/filestorage_base64.cpp
Normal file
71
samples/cpp/filestorage_base64.cpp
Normal file
@ -0,0 +1,71 @@
|
|||||||
|
#include "opencv2/core.hpp"
|
||||||
|
#include <iostream>
|
||||||
|
#include <string>
|
||||||
|
|
||||||
|
static CvFileStorage * three_same_ways_of_write_base64()
|
||||||
|
{
|
||||||
|
CvFileStorage * fs = 0;
|
||||||
|
cv::RNG rng;
|
||||||
|
switch ( rng.uniform( 0, 2 ) )
|
||||||
|
{
|
||||||
|
case 0:
|
||||||
|
//! [suffix_in_file_name]
|
||||||
|
fs = cvOpenFileStorage( "example.yml?base64", 0, CV_STORAGE_WRITE );
|
||||||
|
//! [suffix_in_file_name]
|
||||||
|
break;
|
||||||
|
case 1:
|
||||||
|
//! [flag_write_base64]
|
||||||
|
fs = cvOpenFileStorage( "example.yml" , 0, CV_STORAGE_WRITE_BASE64 );
|
||||||
|
//! [flag_write_base64]
|
||||||
|
break;
|
||||||
|
case 2:
|
||||||
|
//! [flag_write_and_flag_base64]
|
||||||
|
fs = cvOpenFileStorage( "example.yml" , 0, CV_STORAGE_WRITE | CV_STORAGE_BASE64 );
|
||||||
|
//! [flag_write_and_flag_base64]
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
return fs;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void two_ways_to_write_rawdata_in_base64()
|
||||||
|
{
|
||||||
|
std::vector<int> rawdata(10, 0x00010203);
|
||||||
|
|
||||||
|
{ // [1]
|
||||||
|
//! [without_base64_flag]
|
||||||
|
CvFileStorage* fs = cvOpenFileStorage( "example.xml", 0, CV_STORAGE_WRITE );
|
||||||
|
// both CV_NODE_SEQ and "binary" are necessary.
|
||||||
|
cvStartWriteStruct(fs, "rawdata", CV_NODE_SEQ | CV_NODE_FLOW, "binary");
|
||||||
|
cvWriteRawDataBase64(fs, rawdata.data(), rawdata.size(), "i");
|
||||||
|
cvEndWriteStruct(fs);
|
||||||
|
cvReleaseFileStorage( &fs );
|
||||||
|
//! [without_base64_flag]
|
||||||
|
}
|
||||||
|
|
||||||
|
{ // [2]
|
||||||
|
//! [with_write_base64_flag]
|
||||||
|
CvFileStorage* fs = cvOpenFileStorage( "example.xml", 0, CV_STORAGE_WRITE_BASE64);
|
||||||
|
// parameter, typename "binary" could be omitted.
|
||||||
|
cvStartWriteStruct(fs, "rawdata", CV_NODE_SEQ | CV_NODE_FLOW);
|
||||||
|
cvWriteRawData(fs, rawdata.data(), rawdata.size(), "i");
|
||||||
|
cvEndWriteStruct(fs);
|
||||||
|
cvReleaseFileStorage( &fs );
|
||||||
|
//! [with_write_base64_flag]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
int main(int /* argc */, char** /* argv */)
|
||||||
|
{
|
||||||
|
{ // base64 mode
|
||||||
|
CvFileStorage * fs = three_same_ways_of_write_base64();
|
||||||
|
cvReleaseFileStorage( &fs );
|
||||||
|
}
|
||||||
|
|
||||||
|
{ // output rawdata by `cvWriteRawdata*`
|
||||||
|
two_ways_to_write_rawdata_in_base64();
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user