Commit f2e9bf0e59c10a75dadde89514ab531d841484a4
1 parent
d7c2fb94
simplified lmGallery to make use of newly introduced helper functions
Showing
1 changed file
with
4 additions
and
34 deletions
openbr/plugins/gallery/lm.cpp
| @@ -23,37 +23,7 @@ class lmGallery : public Gallery | @@ -23,37 +23,7 @@ class lmGallery : public Gallery | ||
| 23 | { | 23 | { |
| 24 | if (mats.empty()) | 24 | if (mats.empty()) |
| 25 | return; | 25 | return; |
| 26 | - if (!mats.first().data) | ||
| 27 | - qFatal("Null first matrix"); | ||
| 28 | - | ||
| 29 | - const int depth = mats.first().depth(); | ||
| 30 | - const int channels = mats.first().channels(); | ||
| 31 | - const int columns = mats.first().cols; | ||
| 32 | - const int rows = mats.first().rows; | ||
| 33 | - const int frames = mats.size(); | ||
| 34 | - likely_type type = likelyFromOpenCVDepth(depth); | ||
| 35 | - if (channels > 1) type |= likely_multi_channel; | ||
| 36 | - if (columns > 1) type |= likely_multi_column; | ||
| 37 | - if (rows > 1) type |= likely_multi_row; | ||
| 38 | - if (frames > 1) type |= likely_multi_frame; | ||
| 39 | - | ||
| 40 | - const likely_mat m = likely_new(type, channels, columns, rows, frames, NULL); | ||
| 41 | - const size_t step = (type & likely_depth) * channels * columns * rows / 8; | ||
| 42 | - for (size_t i=0; i<size_t(frames); i++) { | ||
| 43 | - const cv::Mat &mat = mats[i]; | ||
| 44 | - if (!mat.isContinuous()) | ||
| 45 | - qFatal("Expected continuous matrix data"); | ||
| 46 | - if (mat.depth() != depth) | ||
| 47 | - qFatal("Depth mismatch"); | ||
| 48 | - if (mat.channels() != channels) | ||
| 49 | - qFatal("Channel mismatch"); | ||
| 50 | - if (mat.cols != columns) | ||
| 51 | - qFatal("Columns mismatch"); | ||
| 52 | - if (mat.rows != rows) | ||
| 53 | - qFatal("Rows mismatch"); | ||
| 54 | - memcpy(m->data + i * step, mat.data, step); | ||
| 55 | - } | ||
| 56 | - | 26 | + likely_const_mat m = likelyFromOpenCVMats(mats.toVector().toStdVector()); |
| 57 | if (!likely_write(m, qPrintable(file.name))) | 27 | if (!likely_write(m, qPrintable(file.name))) |
| 58 | qFatal("Write failed"); | 28 | qFatal("Write failed"); |
| 59 | likely_release_mat(m); | 29 | likely_release_mat(m); |
| @@ -64,9 +34,9 @@ class lmGallery : public Gallery | @@ -64,9 +34,9 @@ class lmGallery : public Gallery | ||
| 64 | *done = true; | 34 | *done = true; |
| 65 | TemplateList templates; | 35 | TemplateList templates; |
| 66 | const likely_const_mat m = likely_read(qPrintable(file.name), likely_file_matrix, likely_void); | 36 | const likely_const_mat m = likely_read(qPrintable(file.name), likely_file_matrix, likely_void); |
| 67 | - const size_t step = (m->type & likely_depth) * m->channels * m->columns * m->rows / 8; | ||
| 68 | - for (size_t i=0; i<m->frames; i++) | ||
| 69 | - templates.append(cv::Mat(m->rows, m->columns, CV_MAKETYPE(likelyToOpenCVDepth(m->type), m->channels), (void*)(m->data + i * step)).clone()); | 37 | + foreach (const cv::Mat &mat, likelyToOpenCVMats(m)) |
| 38 | + templates.append(mat); | ||
| 39 | + likely_release_mat(m); | ||
| 70 | return templates; | 40 | return templates; |
| 71 | } | 41 | } |
| 72 | 42 |