00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018 #ifndef __TEMPLATEMATCHER_H__
00019 #define __TEMPLATEMATCHER_H__
00020
00021 extern "C" {
00022 #include "avcodec.h"
00023 }
00024 #include "FrameAnalyzer.h"
00025
00026 typedef struct AVPicture AVPicture;
00027 class PGMConverter;
00028 class EdgeDetector;
00029 class TemplateFinder;
00030
00031 class TemplateMatcher : public FrameAnalyzer
00032 {
00033 public:
00034
00035 TemplateMatcher(PGMConverter *pgmc, EdgeDetector *ed, TemplateFinder *tf,
00036 QString debugdir);
00037 ~TemplateMatcher(void);
00038
00039
00040 const char *name(void) const { return "TemplateMatcher"; }
00041 enum analyzeFrameResult nuppelVideoPlayerInited(NuppelVideoPlayer *nvp,
00042 long long nframes);
00043 enum analyzeFrameResult analyzeFrame(const VideoFrame *frame,
00044 long long frameno, long long *pNextFrame);
00045 int finished(long long nframes, bool final);
00046 int reportTime(void) const;
00047
00048
00049 int templateCoverage(long long nframes, bool final) const;
00050 const FrameAnalyzer::FrameMap *getBreaks(void) const { return &breakMap; }
00051 int adjustForBlanks(const BlankFrameDetector *bf, long long nframes);
00052 int computeBreaks(FrameMap *breaks);
00053
00054 private:
00055 PGMConverter *pgmConverter;
00056 EdgeDetector *edgeDetector;
00057 TemplateFinder *templateFinder;
00058 const struct AVPicture *tmpl;
00059 int tmplrow, tmplcol;
00060 int tmplwidth, tmplheight;
00061
00062
00063 unsigned short *matches;
00064 unsigned char *match;
00065
00066 float fps;
00067 AVPicture cropped;
00068 FrameAnalyzer::FrameMap breakMap;
00069
00070
00071 int debugLevel;
00072 QString debugdir;
00073 QString debugdata;
00074 NuppelVideoPlayer *nvp;
00075 bool debug_matches;
00076 bool debug_removerunts;
00077 bool matches_done;
00078 struct timeval analyze_time;
00079 };
00080
00081 #endif
00082
00083
00084