2013-08-13 11:10:45 +02:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
// STL includes
|
|
|
|
#include <memory>
|
|
|
|
|
|
|
|
// Jsoncpp includes
|
|
|
|
#include <json/json.h>
|
|
|
|
|
|
|
|
#include <hyperion/LedString.h>
|
|
|
|
|
|
|
|
// Forward class declaration
|
|
|
|
class ImageProcessor;
|
|
|
|
|
2013-09-06 21:26:58 +02:00
|
|
|
///
|
|
|
|
/// The ImageProcessor is a singleton factor for creating ImageProcessors that translate images to
|
|
|
|
/// led color values.
|
|
|
|
///
|
2013-08-13 11:10:45 +02:00
|
|
|
class ImageProcessorFactory
|
|
|
|
{
|
|
|
|
public:
|
2013-09-06 21:26:58 +02:00
|
|
|
///
|
|
|
|
/// Returns the 'singleton' instance (creates the singleton if it does not exist)
|
|
|
|
///
|
|
|
|
/// @return The singleton instance of the ImageProcessorFactory
|
|
|
|
///
|
2013-08-13 11:10:45 +02:00
|
|
|
static ImageProcessorFactory& getInstance();
|
|
|
|
|
|
|
|
public:
|
2013-09-06 21:26:58 +02:00
|
|
|
///
|
|
|
|
/// Initialises this factory with the given led-configuration
|
|
|
|
///
|
|
|
|
/// @param[in] ledString The led configuration
|
|
|
|
///
|
2013-08-13 11:10:45 +02:00
|
|
|
void init(const LedString& ledString);
|
|
|
|
|
2013-09-06 21:26:58 +02:00
|
|
|
///
|
|
|
|
/// Creates a new ImageProcessor. The onwership of the processor is transferred to the caller.
|
|
|
|
///
|
|
|
|
/// @return The newly created ImageProcessor
|
|
|
|
///
|
2013-08-13 11:10:45 +02:00
|
|
|
ImageProcessor* newImageProcessor() const;
|
|
|
|
|
|
|
|
private:
|
2013-09-06 21:26:58 +02:00
|
|
|
/// The Led-string specification
|
2013-08-13 11:10:45 +02:00
|
|
|
LedString _ledString;
|
|
|
|
};
|