mirror of
https://github.com/opencv/opencv.git
synced 2025-01-13 08:08:10 +08:00
c06f3d63e8
- cmake dependencies search (WITH_MFX option) - raw H264, H265, MPEG2 encoding and decoding - tests for supported formats
162 lines
5.5 KiB
C++
162 lines
5.5 KiB
C++
// This file is part of OpenCV project.
|
|
// It is subject to the license terms in the LICENSE file found in the top-level directory
|
|
// of this distribution and at http://opencv.org/license.html
|
|
|
|
#include "test_precomp.hpp"
|
|
#include "opencv2/videoio.hpp"
|
|
#include "opencv2/highgui.hpp"
|
|
#include <sstream>
|
|
#include <queue>
|
|
#include <cstdio>
|
|
|
|
#ifdef HAVE_MFX
|
|
|
|
using namespace cv;
|
|
using namespace std;
|
|
using namespace std::tr1;
|
|
|
|
|
|
TEST(Videoio_MFX, read_invalid)
|
|
{
|
|
VideoCapture cap;
|
|
ASSERT_NO_THROW(cap.open("nonexistent-file", CAP_INTEL_MFX));
|
|
ASSERT_FALSE(cap.isOpened());
|
|
Mat img;
|
|
ASSERT_NO_THROW(cap >> img);
|
|
ASSERT_TRUE(img.empty());
|
|
}
|
|
|
|
TEST(Videoio_MFX, write_invalid)
|
|
{
|
|
const string filename = cv::tempfile(".264");
|
|
VideoWriter writer;
|
|
bool res;
|
|
ASSERT_NO_THROW(res = writer.open(CAP_INTEL_MFX, filename, VideoWriter::fourcc('H', '2', '6', '4'), 1, Size(641, 480), true));
|
|
EXPECT_FALSE(res);
|
|
EXPECT_FALSE(writer.isOpened());
|
|
ASSERT_NO_THROW(res = writer.open(CAP_INTEL_MFX,filename, VideoWriter::fourcc('H', '2', '6', '4'), 1, Size(640, 481), true));
|
|
EXPECT_FALSE(res);
|
|
EXPECT_FALSE(writer.isOpened());
|
|
ASSERT_NO_THROW(res = writer.open(CAP_INTEL_MFX,filename, VideoWriter::fourcc('A', 'B', 'C', 'D'), 1, Size(640, 480), true));
|
|
EXPECT_FALSE(res);
|
|
EXPECT_FALSE(writer.isOpened());
|
|
ASSERT_NO_THROW(res = writer.open(CAP_INTEL_MFX,String(), VideoWriter::fourcc('H', '2', '6', '4'), 1, Size(640, 480), true));
|
|
EXPECT_FALSE(res);
|
|
EXPECT_FALSE(writer.isOpened());
|
|
ASSERT_NO_THROW(res = writer.open(CAP_INTEL_MFX,filename, VideoWriter::fourcc('H', '2', '6', '4'), 0, Size(640, 480), true));
|
|
EXPECT_FALSE(res);
|
|
EXPECT_FALSE(writer.isOpened());
|
|
|
|
ASSERT_NO_THROW(res = writer.open(CAP_INTEL_MFX,filename, VideoWriter::fourcc('H', '2', '6', '4'), 30, Size(640, 480), true));
|
|
ASSERT_TRUE(res);
|
|
ASSERT_TRUE(writer.isOpened());
|
|
Mat t;
|
|
// write some bad frames
|
|
t = Mat(Size(1024, 768), CV_8UC3);
|
|
EXPECT_NO_THROW(writer << t);
|
|
t = Mat(Size(320, 240), CV_8UC3);
|
|
EXPECT_NO_THROW(writer << t);
|
|
t = Mat(Size(640, 480), CV_8UC2);
|
|
EXPECT_NO_THROW(writer << t);
|
|
|
|
// cleanup
|
|
ASSERT_NO_THROW(writer.release());
|
|
remove(filename.c_str());
|
|
}
|
|
|
|
|
|
//==================================================================================================
|
|
|
|
const int FRAME_COUNT = 20;
|
|
|
|
inline void generateFrame(int i, Mat & frame)
|
|
{
|
|
frame = 0;
|
|
ostringstream buf; buf << "Frame " << setw(2) << setfill('0') << i + 1;
|
|
int baseLine = 0;
|
|
Size box = getTextSize(buf.str(), FONT_HERSHEY_COMPLEX, 2, 5, &baseLine);
|
|
putText(frame, buf.str(), Point((frame.cols - box.width) / 2, (frame.rows - box.height) / 2 + baseLine),
|
|
FONT_HERSHEY_COMPLEX, 2, Scalar(255, 255, 255), 5, LINE_AA);
|
|
Point p(i * frame.cols / (FRAME_COUNT - 1), i * frame.rows / (FRAME_COUNT - 1));
|
|
circle(frame, p, 20, Scalar(200, 25, 55), 5, LINE_AA);
|
|
}
|
|
|
|
inline int fourccByExt(const String &ext)
|
|
{
|
|
if (ext == ".mpeg2")
|
|
return VideoWriter::fourcc('M', 'P', 'G', '2');
|
|
else if (ext == ".264")
|
|
return VideoWriter::fourcc('H', '2', '6', '4');
|
|
else if (ext == ".265")
|
|
return VideoWriter::fourcc('H', '2', '6', '5');
|
|
return -1;
|
|
}
|
|
|
|
//==================================================================================================
|
|
|
|
typedef tuple<Size, double, const char *> Size_FPS_Ext;
|
|
typedef testing::TestWithParam< Size_FPS_Ext > Videoio_MFX;
|
|
|
|
TEST_P(Videoio_MFX, read_write_raw)
|
|
{
|
|
const Size FRAME_SIZE = get<0>(GetParam());
|
|
const double FPS = get<1>(GetParam());
|
|
const char *ext = get<2>(GetParam());
|
|
const String filename = cv::tempfile(ext);
|
|
const int fourcc = fourccByExt(ext);
|
|
|
|
bool isColor = true;
|
|
queue<Mat> goodFrames;
|
|
|
|
// Write video
|
|
VideoWriter writer;
|
|
writer.open(CAP_INTEL_MFX, filename, fourcc, FPS, FRAME_SIZE, isColor);
|
|
ASSERT_TRUE(writer.isOpened());
|
|
Mat frame(FRAME_SIZE, CV_8UC3);
|
|
for (int i = 0; i < FRAME_COUNT; ++i)
|
|
{
|
|
generateFrame(i, frame);
|
|
goodFrames.push(frame.clone());
|
|
writer << frame;
|
|
}
|
|
writer.release();
|
|
EXPECT_FALSE(writer.isOpened());
|
|
|
|
// Read video
|
|
VideoCapture cap;
|
|
cap.open(filename, CAP_INTEL_MFX);
|
|
ASSERT_TRUE(cap.isOpened());
|
|
for (int i = 0; i < FRAME_COUNT; ++i)
|
|
{
|
|
ASSERT_TRUE(cap.read(frame));
|
|
ASSERT_FALSE(frame.empty());
|
|
ASSERT_EQ(FRAME_SIZE.width, frame.cols);
|
|
ASSERT_EQ(FRAME_SIZE.height, frame.rows);
|
|
// verify
|
|
ASSERT_NE(goodFrames.size(), 0u);
|
|
const Mat &goodFrame = goodFrames.front();
|
|
EXPECT_EQ(goodFrame.depth(), frame.depth());
|
|
EXPECT_EQ(goodFrame.channels(), frame.channels());
|
|
EXPECT_EQ(goodFrame.type(), frame.type());
|
|
double psnr = cvtest::PSNR(goodFrame, frame);
|
|
if (fourcc == VideoWriter::fourcc('M', 'P', 'G', '2'))
|
|
EXPECT_GT(psnr, 37); // experimentally chosen value
|
|
else
|
|
EXPECT_GT(psnr, 43); // experimentally chosen value
|
|
goodFrames.pop();
|
|
}
|
|
EXPECT_FALSE(cap.read(frame));
|
|
EXPECT_TRUE(frame.empty());
|
|
cap.release();
|
|
EXPECT_FALSE(cap.isOpened());
|
|
remove(filename.c_str());
|
|
}
|
|
|
|
INSTANTIATE_TEST_CASE_P(videoio, Videoio_MFX,
|
|
testing::Combine(
|
|
testing::Values(Size(640, 480), Size(638, 478), Size(636, 476), Size(1920, 1080)),
|
|
testing::Values(1, 30, 100),
|
|
testing::Values(".mpeg2", ".264", ".265")));
|
|
|
|
#endif
|