src/qvworkers/qvharrispointdetector.cpp

Go to the documentation of this file.
00001 /*
00002  *      Copyright (C) 2007, 2008. PARP Research Group.
00003  *      <http://perception.inf.um.es>
00004  *      University of Murcia, Spain.
00005  *
00006  *      This file is part of the QVision library.
00007  *
00008  *      QVision is free software: you can redistribute it and/or modify
00009  *      it under the terms of the GNU Lesser General Public License as
00010  *      published by the Free Software Foundation, version 3 of the License.
00011  *
00012  *      QVision is distributed in the hope that it will be useful,
00013  *      but WITHOUT ANY WARRANTY; without even the implied warranty of
00014  *      MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
00015  *      GNU Lesser General Public License for more details.
00016  *
00017  *      You should have received a copy of the GNU Lesser General Public
00018  *      License along with QVision. If not, see <http://www.gnu.org/licenses/>.
00019  */
00020 
00024 
00025 #include <QList>
00026 #include <QPointF>
00027 
00028 #include <qvdta.h>
00029 #include <qvip.h>
00030 #include <QVPolylineF>
00031 
00032 #include <QVHarrisPointDetector>
00033 
00034 Q_DECLARE_METATYPE(QList<QPointF>);
00035 
00036 #ifndef DOXYGEN_IGNORE_THIS
00037 QVHarrisPointDetector::QVHarrisPointDetector(QString name): QVWorker(name)
00038         {
00039         addProperty< int >("Points", inputFlag, 15, "window size ", 1, 100);
00040         addProperty< double >("Threshold", inputFlag, 1.0, "window size ", 0.0, 256.0);
00041 
00042         addProperty< QVImage<uChar,3> >("Input image", inputFlag|outputFlag);
00043         addProperty< QList<QPointF> >("Corners", outputFlag);
00044         }
00045 
00046 void QVHarrisPointDetector::iterate()
00047         {
00048         // 0. Read input parameters
00049         const QVImage<uChar> image = getPropertyValue< QVImage<uChar,3> >("Input image");
00050         const double threshold = getPropertyValue<double>("Threshold");
00051         const int pointNumber = getPropertyValue<int>("Points");
00052         timeFlag("grab Frame");
00053 
00054         // 1. Obtain corner response image.
00055         QVImage<sFloat> cornerResponseImage(image.getRows(), image.getCols());
00056         FilterHessianCornerResponseImage(image, cornerResponseImage);
00057         timeFlag("Corner response image");
00058 
00059         // 2. Local maximal filter.
00060         QList<QPointF> hotPoints = GetMaximalResponsePoints3(cornerResponseImage, threshold);
00061         timeFlag("Local maximal filter");
00062 
00063         // 3. Output resulting data.
00064         //setPropertyValue< QVImage<uChar,1> >("Output image", image);
00065         setPropertyValue< QList<QPointF> >("Corners", hotPoints.mid(MAX(0,hotPoints.size() - pointNumber)));
00066         }
00067 #endif