-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathframeObject.h
131 lines (119 loc) · 2.76 KB
/
frameObject.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
//#ifndef _FrameObject_
//#define _FrameObject_
#include <cv.h>
#include <list>
#include "shadow.h"
#include "initializationParams.h"
using namespace std;
/*!
//@typedef DetectedObject
*/
typedef struct _DetectedObject
{
/*!
//Maschera dell'oggetto con la sua ombra*/
IplImage * totalMask;
/*!
//Maschera dell'oggetto*/
IplImage * mvoMask;
/*!
//Maschera dell'ombra*/
IplImage * shadowMask;
/*!
//Maschera invertita dell'ombra*/
IplImage * invertedShadowMask;
/*!
//Blobs dell'mvo*/
CvBlobs mvoBlobs;
IplImage *mvo;
bool isGhost;
//!Constructor
_DetectedObject(CvSize size,int depth){
try{
mvo = cvCreateImage(size,depth,3);
cvZero(mvo);
totalMask = cvCreateImage(size,depth,1);
mvoMask = cvCreateImage(size,depth,1);
shadowMask = cvCreateImage(size,depth,1);
invertedShadowMask = cvCreateImage(size,depth,1);
mvoBlobs = CvBlobs();
isGhost=FALSE;
}
catch(exception& e)
{
throw e.what();
}
}
~_DetectedObject(){
try{
cvReleaseImage(&totalMask);
cvReleaseImage(&mvo);
cvReleaseImage(&mvoMask);
cvReleaseImage(&shadowMask);
cvReleaseImage(&invertedShadowMask);
cvReleaseBlobs(mvoBlobs);
}
catch(exception& e){
throw e.what();
}
}
}
DetectedObject;
/*!
//Classe wrap per un singolo frame*/
class FrameObject{
private:
/*!
//il frame*/
IplImage * frame;
/*!
//il background*/
IplImage * background;
/*!
//maschera del foreground del frame*/
IplImage * foregroundMask;
/*!
//maschera del salient foreground*/
IplImage * salientForegroundMask;
/*!
//lista contenente i singoli oggetti rilevati nel frame*/
list<DetectedObject*> detectedObject;
/*!
//numero del frame*/
int frameNumber;
/*!
//dimensione in pizel del frame*/
CvSize size;
/*!
//Blobs della scena*/
CvBlobs frameBlobs;
bool isToSave(IplImage* vMask,IplImage *mask,int threashold);
public:
/*!
//default constructor*/
FrameObject();
~FrameObject();
/*!
//constructor with parameter*/
FrameObject(IplImage * currentFrame, IplImage * currentBackground, IplImage* salient,int nFrame);
/*!
//ritorna una copia del frame*/
IplImage * getFrame();
/*!
//ritorna una copia del background*/
IplImage * getBackground();
/*!
//ritorna una copia della maschera del foreground del frame*/
IplImage * getForegroundMask();
IplImage * getSalientMask();
/*!
//ritorna il numero di sequenza del frame*/
int getFrameNumber();
/*!
//esegue il detecting di tutti gli oggetti nella scena e ne salva Mvo e shadow nella lista detectedObject*/
void detectAll(initializationParams initPar);
/*!
//ritorna la lista degli ogetti trovati nella scena*/
list<DetectedObject*> getDetectedObject();
};
//#endif