/////////////////////////////////////////////////////////////////////////////
// Name: crvcamera.cpp
// Purpose:
// Author: Cesar Mauri Loba (cesar at crea-si dot com)
// Modified by:
// Created: 30/05/2008
// Copyright: (C) 2008-10 Cesar Mauri Loba - CREA Software Systems
//
// 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, either version 3 of the License, or
// (at your option) any later version.
//
// 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 General Public License
// along with this program. If not, see .
/////////////////////////////////////////////////////////////////////////////
#include "crvcamera.h"
#include "crvimage.h"
#include
#include
#include
#include
// Return timestamp in ms
static long long GetTime (void)
{
struct timeb now;
ftime(&now);
return now.time*1000 + now.millitm;
}
CCamera::CCamera() throw (camera_exception)
{
m_RealWidth=0;
m_RealHeight= 0;
m_RealFrameRate= 0.0f;
m_LastRealFrameRate= 0.0f;
m_lastTimeStamp= GetTime();
m_horizontalFlip= false;
}
CCamera::~CCamera(void)
{
// Should call Close but is not done here
// because DoClose is virtual. We rely on
// derived classes
}
bool CCamera::Open()
{
bool retval= DoOpen();
if (retval) m_lastTimeStamp= GetTime();
return retval;
}
void CCamera::Close()
{
DoClose();
}
IplImage* CCamera::QueryFrame()
{
IplImage* pImage= DoQueryFrame();
if (!pImage) return NULL;
PostQueryFrame(pImage);
return pImage;
}
void CCamera::PostQueryFrame(IplImage* pImage)
{
// Update real size
m_RealWidth= pImage->width;
m_RealHeight= pImage->height;
// Update real FPS
long long now= GetTime();
long long elapsedTime= now - m_lastTimeStamp;
m_lastTimeStamp= now;
m_LastRealFrameRate= m_RealFrameRate;
float weight= ((float) elapsedTime / 1000.0f) * 1.5f;
if (weight> 1.0f) weight= 1.0f;
if (elapsedTime> 0)
m_RealFrameRate= (1000.0f / (float) elapsedTime) * weight + m_LastRealFrameRate * (1.0f - weight);
else
m_RealFrameRate= 0;
// Flip image when needed to provide an image with top-left origin
if ( pImage->origin == 1 ) {
if (m_horizontalFlip)
cvFlip (pImage, NULL, -1);
else
cvFlip (pImage, NULL, 0);
pImage->origin= 0;
}
else
if (m_horizontalFlip)
cvFlip (pImage, NULL, 1);
}