summaryrefslogtreecommitdiffhomepage
path: root/tracker-pt/module/frame.cpp
diff options
context:
space:
mode:
authorStanislaw Halik <sthalik@misaki.pl>2021-08-18 13:50:04 +0200
committerStanislaw Halik <sthalik@misaki.pl>2021-08-18 13:53:47 +0200
commitd6907613e89b906edb3f2b7c0049f8b13f3524ee (patch)
treee88d83b15724f0b2915eb555ea2f47f179b5bddf /tracker-pt/module/frame.cpp
parentcfd70f5aea911db4cab1a8f2916d40ac59854166 (diff)
tracker/pt: fix support for grayscale input video
Diffstat (limited to 'tracker-pt/module/frame.cpp')
-rw-r--r--tracker-pt/module/frame.cpp25
1 files changed, 19 insertions, 6 deletions
diff --git a/tracker-pt/module/frame.cpp b/tracker-pt/module/frame.cpp
index ab110871..9247212b 100644
--- a/tracker-pt/module/frame.cpp
+++ b/tracker-pt/module/frame.cpp
@@ -8,19 +8,32 @@ namespace pt_module {
Preview& Preview::operator=(const pt_frame& frame_)
{
- const cv::Mat& frame = frame_.as_const<const Frame>()->mat;
+ const cv::Mat& frame2 = frame_.as_const<const Frame>()->mat;
+ const cv::Mat* frame;
- if (frame.channels() != 3)
+ if (frame2.channels() == 1)
{
- eval_once(qDebug() << "tracker/pt: camera frame depth: 3 !=" << frame.channels());
+ frame_tmp.create(frame2.rows, frame2.cols, CV_8UC3);
+ const cv::Mat channels[] = { frame2, frame2, frame2 };
+ cv::merge(channels, std::size(channels), frame_tmp);
+ frame = &frame_tmp;
+ }
+ else
+ frame = &frame2;
+
+ if (frame->channels() != 3)
+ {
+ eval_once(qDebug() << "tracker/pt: camera frame depth: 3 !=" << frame->channels());
+ frame_copy.create(cv::Size{frame_out.cols, frame_out.rows}, CV_8UC3);
+ frame_copy.setTo({0});
return *this;
}
- const bool need_resize = frame.cols != frame_out.cols || frame.rows != frame_out.rows;
+ const bool need_resize = frame2.cols != frame_out.cols || frame2.rows != frame_out.rows;
if (need_resize)
- cv::resize(frame, frame_copy, cv::Size(frame_out.cols, frame_out.rows), 0, 0, cv::INTER_NEAREST);
+ cv::resize(frame2, frame_copy, cv::Size(frame_out.cols, frame_out.rows), 0, 0, cv::INTER_NEAREST);
else
- frame.copyTo(frame_copy);
+ frame->copyTo(frame_copy);
return *this;
}