| Es++ Class: OpenCVImageConverter |
/******************************************************************************
*
* Copyright (c) 2017 Antillia.com TOSHIYUKI ARAI. ALL RIGHTS RESERVED.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions, and the following disclaimer.
*
* 2. The name of the author may not be used to endorse or promote products
* derived from this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
* IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
* OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
* IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
* OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
* WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
* OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
* ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*
*
* OpenCVImageConverter.h
*
*****************************************************************************/
// 2019/01/01 Modified to support OpenCV-4.0.1 based on
// precomp.hpp and window_gtk.cpp in /opencv/sources/modules/highgui/src
// of OpenCV-4.0.1
//
#pragma once
#include <es++/Exception.h>
#include <es++/opencv-4.0/OpenCVObject.h>
namespace Es {
class OpenCVImageConverter {
public:
//Convert cv::Mat to Gdk::Pixbuf;
static
Glib::RefPtr<Gdk::Pixbuf> convertToPixbuf(cv::Mat& m)
{
IplImage image = m;
dprintf("fromMatToPixbuf depth=%d channels=%d\n",
image.depth, image.nChannels);
CvMat* mat, stub;
mat = cvGetMat(&image, &stub);
//CV_8UC3 is color 24 bit cvMat image.
CvMat* destImage = cvCreateMat(mat->rows, mat->cols, CV_8UC3);
if (destImage == NULL) {
throw Es::IException("Failed to cvCreateMat");
}
int origin = image.origin;
convertToShow(cv::cvarrToMat(&image), destImage);
Glib::RefPtr<Gdk::Pixbuf>
pixbuf = Glib::wrap(gdk_pixbuf_new_from_data(
destImage->data.ptr,
GDK_COLORSPACE_RGB ,
false,
8,
destImage->cols,
destImage->rows,
destImage->step,
NULL,
NULL)
);
//Don't need release destImage.
// cvReleaseMat(&destImage);
return pixbuf;
}
//From precomp.hpp
static
void convertToShow(const cv::Mat &src, cv::Mat &dst, bool toRGB = true)
{
const int src_depth = src.depth();
CV_Assert(src_depth != CV_16F && src_depth != CV_32S);
cv::Mat tmp;
switch(src_depth)
{
case CV_8U:
tmp = src;
break;
case CV_8S:
cv::convertScaleAbs(src, tmp, 1, 127);
break;
case CV_16S:
cv::convertScaleAbs(src, tmp, 1/255., 127);
break;
case CV_16U:
cv::convertScaleAbs(src, tmp, 1/255.);
break;
case CV_32F:
case CV_64F: // assuming image has values in range [0, 1)
cv::convertScaleAbs(src, tmp, 256.);
break;
}
cv::cvtColor(tmp, dst, toRGB ? cv::COLOR_BGR2RGB : cv::COLOR_BGRA2BGR, dst.channels());
}
//From precomp.hpp
static
void convertToShow(const cv::Mat &src, const CvMat* arr, bool toRGB = true)
{
cv::Mat dst = cv::cvarrToMat(arr);
convertToShow(src, dst, toRGB);
CV_Assert(dst.data == arr->data.ptr);
}
};
}