/*
* EtherPix config file generator
*
* Copyright 2010-2017 Stefan Schuermans <stefan schuermans info>
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, version 3 of the License.
*
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#ifndef INC_PIXEL_H
#define INC_PIXEL_H
#include <iostream>
#include "box.h"
#include "object.h"
#include "point.h"
class Pixel {
public:
Pixel(const Object *pObjPixel);
/**
* @brief compute coordinate of pixel and check it
* @param[in] pix0 position of logical pixel origin
* (top left corner of 0,0 of video frame)
* @param[in] pixSz size of one logcal pixel (in video frame)
* @param[in] width of video frame in pixels
* @param[in] height of video frame in pixels
*/
int pixCoord(const Point &pix0, const Point &pixSz,
unsigned int width, unsigned int height);
void writePixel(std::ostream & strm) const;
void writeSimPixel(std::ostream & strm, const Box & boundsVideoQuad) const;
private:
const Object *mpObjPixel;
Box mBounds;
Point mCenter;
unsigned int mX, mY;
};
#endif // #ifndef INC_PIXEL_H