2013-08-13 11:10:45 +02:00
|
|
|
|
2013-08-23 05:09:09 +00:00
|
|
|
// Hyperion includes
|
|
|
|
#include <hyperion/ImageProcessor.h>
|
2013-08-13 11:10:45 +02:00
|
|
|
|
2013-08-23 16:24:10 +00:00
|
|
|
#include <utils/ColorTransform.h>
|
|
|
|
|
2013-08-23 05:09:09 +00:00
|
|
|
// Local-Hyperion includes
|
|
|
|
#include "BlackBorderProcessor.h"
|
|
|
|
#include "ImageToLedsMap.h"
|
2013-08-13 11:10:45 +02:00
|
|
|
|
|
|
|
using namespace hyperion;
|
|
|
|
|
|
|
|
ImageProcessor::ImageProcessor(const LedString& ledString) :
|
|
|
|
mLedString(ledString),
|
2013-08-23 05:09:09 +00:00
|
|
|
_enableBlackBorderRemoval(true),
|
|
|
|
_borderProcessor(new BlackBorderProcessor(600, 50, 1)),
|
2013-08-13 11:10:45 +02:00
|
|
|
mImageToLeds(nullptr)
|
|
|
|
{
|
|
|
|
// empty
|
|
|
|
}
|
|
|
|
|
|
|
|
ImageProcessor::~ImageProcessor()
|
|
|
|
{
|
|
|
|
delete mImageToLeds;
|
2013-08-23 05:09:09 +00:00
|
|
|
delete _borderProcessor;
|
2013-08-13 11:10:45 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
void ImageProcessor::setSize(const unsigned width, const unsigned height)
|
|
|
|
{
|
|
|
|
// Check if the existing buffer-image is already the correct dimensions
|
2013-08-14 15:02:09 +00:00
|
|
|
if (mImageToLeds && mImageToLeds->width() == width && mImageToLeds->height() == height)
|
2013-08-13 11:10:45 +02:00
|
|
|
{
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Clean up the old buffer and mapping
|
|
|
|
delete mImageToLeds;
|
|
|
|
|
|
|
|
// Construct a new buffer and mapping
|
2013-08-21 15:24:42 +00:00
|
|
|
mImageToLeds = new ImageToLedsMap(width, height, 0, 0, mLedString.leds());
|
2013-08-13 11:10:45 +02:00
|
|
|
}
|
|
|
|
|
2013-08-14 15:02:09 +00:00
|
|
|
std::vector<RgbColor> ImageProcessor::process(const RgbImage& image)
|
2013-08-13 11:10:45 +02:00
|
|
|
{
|
2013-08-14 15:02:09 +00:00
|
|
|
// Ensure that the buffer-image is the proper size
|
|
|
|
setSize(image.width(), image.height());
|
|
|
|
|
2013-08-23 05:09:09 +00:00
|
|
|
// Check black border detection
|
|
|
|
verifyBorder(image);
|
|
|
|
|
2013-08-14 15:02:09 +00:00
|
|
|
// Create a result vector and call the 'in place' functionl
|
|
|
|
std::vector<RgbColor> colors = mImageToLeds->getMeanLedColor(image);
|
|
|
|
|
|
|
|
// return the computed colors
|
|
|
|
return colors;
|
2013-08-13 11:10:45 +02:00
|
|
|
}
|
|
|
|
|
2013-08-14 15:02:09 +00:00
|
|
|
void ImageProcessor::process(const RgbImage& image, std::vector<RgbColor>& ledColors)
|
2013-08-13 11:10:45 +02:00
|
|
|
{
|
2013-08-23 05:09:09 +00:00
|
|
|
// Check black border detection
|
|
|
|
verifyBorder(image);
|
|
|
|
|
2013-08-13 11:10:45 +02:00
|
|
|
// Determine the mean-colors of each led (using the existing mapping)
|
2013-08-14 15:02:09 +00:00
|
|
|
mImageToLeds->getMeanLedColor(image, ledColors);
|
2013-08-13 11:10:45 +02:00
|
|
|
}
|
2013-08-23 05:09:09 +00:00
|
|
|
|
|
|
|
void ImageProcessor::verifyBorder(const RgbImage& image)
|
|
|
|
{
|
|
|
|
if(_enableBlackBorderRemoval && _borderProcessor->process(image))
|
|
|
|
{
|
|
|
|
std::cout << "BORDER SWITCH REQUIRED!!" << std::endl;
|
|
|
|
|
|
|
|
const BlackBorder border = _borderProcessor->getCurrentBorder();
|
|
|
|
|
|
|
|
// Clean up the old mapping
|
|
|
|
delete mImageToLeds;
|
|
|
|
|
|
|
|
switch (border.type)
|
|
|
|
{
|
|
|
|
case BlackBorder::none:
|
|
|
|
case BlackBorder::unknown:
|
|
|
|
// Construct a new buffer and mapping
|
|
|
|
mImageToLeds = new ImageToLedsMap(image.width(), image.height(), 0, 0, mLedString.leds());
|
|
|
|
break;
|
|
|
|
case BlackBorder::horizontal:
|
|
|
|
// Construct a new buffer and mapping
|
|
|
|
mImageToLeds = new ImageToLedsMap(image.width(), image.height(), border.size, 0, mLedString.leds());
|
|
|
|
break;
|
|
|
|
case BlackBorder::vertical:
|
|
|
|
// Construct a new buffer and mapping
|
|
|
|
mImageToLeds = new ImageToLedsMap(image.width(), image.height(), 0, border.size, mLedString.leds());
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
std::cout << "CURRENT BORDER TYPE: " << _borderProcessor->getCurrentBorder().type << " (size=" << _borderProcessor->getCurrentBorder().size << ")" << std::endl;
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|