This repository has been archived by the owner on Apr 3, 2020. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathttmap.h
80 lines (65 loc) · 1.75 KB
/
ttmap.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
#ifndef TTMAP_H
#define TTMAP_H
#include <QWidget>
#include <QList>
#include "datasource/targetgenerator.h"
#include "view/targetgroupview.h"
#include <QTimer>
#include <QMouseEvent>
#include "filter/targettracker.h"
/*
* 地图
* 用于显示目标
*/
class TTMap : public QWidget
{
Q_OBJECT
public:
explicit TTMap(QWidget *parent = 0);
void paintEvent(QPaintEvent *);
void mouseReleaseEvent(QMouseEvent *);
// 所模拟的区域大小
const static int WIDTH = 20000;
const static int HEIGHT = 20000;
signals:
// 目标位置更新是发送此信号
void targetsUpdated();
//
// 当有目标被选中的时候,发送此信号。
// grp可以为NULL, 为NULL的时候表示没有目标被选中
//
void targetSelectet(TargetGroup *grp);
public slots:
// 开始跟踪
void start();
// 停止跟踪
void stop();
// 处理定时器的超时事件
void timeOutHandler();
// 暂停
void pause(bool);
private:
TargetGenerator *targetGenerator;
QList<TargetGroupView*> views;
int margin; // 坐标系周围的留白
QTimer timer; // 定时器
/**
* @brief targetTracker 目标跟踪器
* 负责通过目标生成器获取的各个目标的测量状态,对目标进行滤波计算。
* 这个过程暂时省略了数据关联部分,所有的测量值都是和目标对应的。
*/
TargetTracker *targetTracker;
//
// 获取被点击的集群
//
TargetGroup* getClickedTargetGroup(int x, int y);
//
// 计算点击的点和集群的最近距离
//
float getTargetGroupDist(TargetGroup *grp, int x, int y);
//
// 绘制坐标系
//
void drawAxes(QPainter &painter);
};
#endif // TTMAP_H