added support for ground truth points: \n -layer for gt points \n -button with icon

-saving and loading support
This commit is contained in:
toni
2016-12-01 19:42:13 +01:00
parent 674f79c150
commit 1da9d916b3
12 changed files with 341 additions and 4 deletions

View File

@@ -125,7 +125,10 @@ HEADERS += MainWindow.h \
mapview/2D/Scaler.h \
mapview/2D/MV2DElementElevator.h \
mapview/model/MMFloorElevators.h \
mapview/model/MMFloorElevator.h
mapview/model/MMFloorElevator.h \
mapview/model/MMFloorGroundTruthPoints.h \
mapview/model/MMFloorGroundTruthPoint.h \
mapview/2D/MV2DElementGroundTruthPoint.h
FORMS += MainWindow.ui

View File

@@ -84,10 +84,13 @@ MainController::MainController() {
//mapModel->load("../IndoorMap/maps/SHL21.xml");
//mapModel->load("../IndoorMap/maps/test.xml");
//mapModel->load("/mnt/data/workspaces/IPIN2016/IPIN2016/competition/maps/CAR/CAR9.xml");
mapModel->load("/mnt/data/workspaces/IPIN2016/IPIN2016/competition/maps/UAH/UAH9.xml");
//mapModel->load("/home/toni/Documents/programme/localization/IPIN2016/competition/src/competition/map/CAR/CAR10.xml");
mapModel->load("/home/toni/Documents/programme/localization/IPIN2016/competition/src/competition/map/UAH/UAH12_rawObstacles.xml");
//mapModel->load("/home/toni/Documents/programme/localization/IPIN2016/competition/src/competition/map/SHL/SHL25.xml");
//mapModel->load("/home/toni/Documents/programme/localization/IPIN2016/competition/src/competition/map/UJI-UB/UJI-UB5.xml");
//mapModel->load("/home/toni/Documents/programme/localization/IPIN2016/competition/src/competition/map/UJI-TI/UJI-TI4.xml");
//mapModel->load("/mnt/data/workspaces/IPIN2016/IPIN2016/competition/maps/UJI-TI/UJI-TI4.xml");
//mapModel->load("/mnt/data/workspaces/IPIN2016/IPIN2016/competition/maps/UJI-UB/UJI-UB4.xml");
//mapModel->load("/home/toni/Documents/programme/localization/IPIN2016/competition/src/competition/map/UJI-UB/UJI-UB5.xml");
//mapModel->load("/mnt/data/workspaces/Indoor/tests/data/WalkHeadingMap.xml");
//mapModel->load("/mnt/data/workspaces/IPIN2016/IPIN2016/competition/maps/test.xml");

View File

@@ -0,0 +1,119 @@
#ifndef MV2DELEMENTGROUNDTRUTHPOINT_H
#define MV2DELEMENTGROUNDTRUTHPOINT_H
#include "MV2DElement.h"
#include "HasMoveableNodes.h"
#include "MapViewElementHelper.h"
#include <Indoor/floorplan/v2/Floorplan.h>
#include "../../UIHelper.h"
class MV2DElementGroundTruthPoint : public MV2DElement, public HasMoveableNodes {
private:
//bool sel = false;
Floorplan::GroundTruthPoint* gtp;
public:
/** ctor with the AP to render/edit */
MV2DElementGroundTruthPoint(Floorplan::GroundTruthPoint* gtp) : gtp(gtp) {;}
/** get the element's 3D bounding box */
BBox2 getBoundingBox() const override {
BBox2 bbox;
bbox.add(Point2(gtp->pos.x, gtp->pos.y));
bbox.grow(Point2(0.1, 0.1));
return bbox;
}
/** get the element's minimal distance (nearest whatsoever) to the given point */
float getMinDistanceXY(const Point2 p) const override {
return p.getDistance(gtp->pos);
}
/** repaint me */
void paint(Painter& p) override {
static const QPixmap& pixmapUnfocused = UIHelper::getPixmapColored("gtp", CFG::UNFOCUS_COLOR, 16);
static const QPixmap& pixmapFocused = UIHelper::getPixmapColored("gtp", CFG::FOCUS_COLOR, 16);
static const QPixmap& pixmapSel = UIHelper::getPixmapColored("gtp", CFG::SEL_COLOR, 16);
if (selectedUserIdx == 0) {
// p.setPenBrush(Qt::black, CFG::SEL_COLOR);
// p.drawCircle(gtp->pos);
p.drawPixmap(gtp->pos, pixmapSel);
} else if (hasFocus()) {
// p.setPenBrush(Qt::black, Qt::NoBrush);
// p.drawCircle(gtp->pos);
p.drawPixmap(gtp->pos, pixmapFocused);
} else {
// p.setPenBrush(Qt::gray, Qt::NoBrush);
// p.drawCircle(gtp->pos);
p.drawPixmap(gtp->pos, pixmapUnfocused);
}
// label
p.setPenBrush(Qt::black, Qt::NoBrush);
p.drawDot(gtp->pos);
if (p.getScaler().getScale() >= 10) {
const std::string str = std::to_string(gtp->id);
p.p->drawText(p.getScaler().xms(gtp->pos.x) + 10, p.getScaler().yms(gtp->pos.y) + 5, str.c_str());
}
}
virtual std::vector<MoveableNode> getMoveableNodes() const override {
return { MoveableNode(0, gtp->pos) };
}
virtual void onNodeMove(MapView2D* v, const int userIdx, const Point2 newPos) override {
(void) v;
if (userIdx == 0) {gtp->pos = newPos;}
}
/** mouse pressed at the given point */
virtual void mousePressed(MapView2D* v, const Point2 p) override {
(void) v;
(void) p;
}
/** mouse moved to the given point */
virtual void mouseMove(MapView2D* v, const Point2 p) override {
(void) v;
(void) p;
// if (sel) {
// const Point2 p = v->getScaler().snap(_p);
// gtp->pos.x = p.x;
// gtp->pos.y = p.y;
// }
}
/** mouse released */
virtual void mouseReleased(MapView2D* v, const Point2 p) override {
(void) v;
(void) p;
}
virtual bool keyPressEvent(MapView2D* v, QKeyEvent *e) override {
(void) v;
(void) e;
return false;
}
virtual void onFocus() override {
;
}
virtual void onUnfocus() override {
;
}
};
#endif // MV2DELEMENTGROUNDTRUTHPOINT_H

View File

@@ -8,6 +8,8 @@ struct MyNode : public GridNode, public GridPoint, public GridNodeImportance {
MyNode(float x, float y, float z) : GridPoint(x,y,z) {;}
float walkImportance;
};
#endif // MYNODE_H

View File

@@ -10,6 +10,7 @@
#include "MMFloorPOIs.h"
#include "MMFloorStairs.h"
#include "MMFloorElevators.h"
#include "MMFloorGroundTruthPoints.h"
#include "IHasParams.h"
@@ -41,6 +42,7 @@ public:
new MMFloorPOIs(this, floor);
new MMFloorStairs(this, floor);
new MMFloorElevators(this, floor);
new MMFloorGroundTruthPoints(this, floor);
}

View File

@@ -0,0 +1,61 @@
#ifndef MMFLOORGROUNDTRUTHPOINT_H
#define MMFLOORGROUNDTRUTHPOINT_H
#include "MapModelElement.h"
#include "IHasParams.h"
#include "../2D/MV2DElementGroundTruthPoint.h"
#include <Indoor/floorplan/v2/Floorplan.h>
class MMFloorGroundTruthPoint : public MapModelElement, public IHasParams {
private:
Floorplan::Floor* floor;
Floorplan::GroundTruthPoint* gtp;
MV2DElementGroundTruthPoint mv2d;
public:
MMFloorGroundTruthPoint(MapLayer* parent, Floorplan::Floor* floor, Floorplan::GroundTruthPoint* gtp) : MapModelElement(parent), floor(floor), gtp(gtp), mv2d(gtp) {
;
}
virtual int getNumParams() const override {
return 2;
}
virtual Param getParamDesc(const int idx) const override {
switch(idx) {
case 0: return Param("id", ParamType::INT);
case 1: return Param("position", ParamType::POINT2);
}
throw 1;
}
virtual ParamValue getParamValue(const int idx) const override {
switch(idx) {
case 0: return gtp->id; //TODO: this value can be changed and isn't set incremental within the indoormap
case 1: return gtp->pos;
}
throw 1;
}
virtual void setParamValue(const int idx, const ParamValue& val) const override {
switch(idx) {
case 0: gtp->id = val.toInt(); break;
case 1: gtp->pos = val.toPoint2(); break;
}
}
MV2DElement* getMV2D() const override {return (MV2DElement*) &mv2d;}
void deleteMe() const override {
parent->removeElement(this);
floor->gtpoints.erase(std::remove(floor->gtpoints.begin(), floor->gtpoints.end(), gtp), floor->gtpoints.end());
}
};
#endif // MMFLOORGROUNDTRUTHPOINT_H

View File

@@ -0,0 +1,46 @@
#ifndef MMFLOORGROUNDTRUTHPOINTS_H
#define MMFLOORGROUNDTRUTHPOINTS_H
#include "MapLayer.h"
#include "MMFloorGroundTruthPoint.h"
#include <Indoor/floorplan/v2/Floorplan.h>
/**
* layer that contains all of one floor's GroundTruthPoints
*/
class MMFloorGroundTruthPoints : public MapLayer {
Floorplan::Floor* floor;
public:
/** ctor with the floor */
MMFloorGroundTruthPoints(MapLayer* parent, Floorplan::Floor* floor) : MapLayer(parent, MapLayerType::FLOOR_GROUND_TRUTH_POINTS), floor(floor) {
// the POIs
for (Floorplan::GroundTruthPoint* gtp : floor->gtpoints) {
elements.push_back(new MMFloorGroundTruthPoint(this, floor, gtp));
}
}
/** get the corresponding floor from the underlying model */
Floorplan::Floor* getFloor() {return floor;}
//TODO: check
void createGroundTruthPoint(Floorplan::GroundTruthPoint* gtp) {
// add to underlying model
floor->gtpoints.push_back(gtp);
// add to myself as element
elements.push_back(new MMFloorGroundTruthPoint(this, floor, gtp));
}
std::string getLayerName() const override {return "GroundTruthPoints";}
};
#endif // MMFLOORGROUNDTRUTHPOINTS_H

View File

@@ -21,6 +21,7 @@ enum class MapLayerType {
FLOOR_UNDERLAYS,
FLOOR_POIS,
FLOOR_STAIRS,
FLOOR_GROUND_TRUTH_POINTS
};

View File

@@ -12,6 +12,7 @@
#include "../mapview/model/MapModel.h"
#include "../mapview/model/MMFloorAccessPoint.h"
#include "../mapview/model/MMFloorBeacon.h"
#include "../mapview/model/MMFloorGroundTruthPoints.h"
#include "../UIHelper.h"
@@ -86,6 +87,12 @@ ToolBoxWidget::ToolBoxWidget(MapView2D* view, QWidget *parent) : QWidget(parent)
lay->addWidget(btnPOI, r++, 0, 1,1,Qt::AlignTop);
connect(btnPOI, SIGNAL(clicked(bool)), this, SLOT(onNewPOI()));
// GROUNDTRUTH
btnGTP = new QPushButton(UIHelper::getIcon("gtp"), "");
btnGTP->setMinimumSize(s,s);
lay->addWidget(btnGTP, r++, 0, 1,1,Qt::AlignTop);
connect(btnGTP, SIGNAL(clicked(bool)), this, SLOT(onNewGTP()));
// FILL
lay->addItem(new QSpacerItem(0,0,QSizePolicy::Minimum, QSizePolicy::MinimumExpanding), r, 0);
@@ -110,6 +117,7 @@ void ToolBoxWidget::setSelectedLayer(MapLayer *ml) {
btnWifi->setEnabled(ml && (ml->getLayerType() == MapLayerType::FLOOR_ACCESS_POINTS));
btnBeacon->setEnabled(ml && (ml->getLayerType() == MapLayerType::FLOOR_BEACONS));
btnPOI->setEnabled(ml && (ml->getLayerType() == MapLayerType::FLOOR_POIS));
btnGTP->setEnabled(ml && (ml->getLayerType() == MapLayerType::FLOOR_GROUND_TRUTH_POINTS));
btnImage->setEnabled(ml && (ml->getLayerType() == MapLayerType::FLOOR_UNDERLAYS));
@@ -557,6 +565,18 @@ void ToolBoxWidget::onNewPOI() {
}
void ToolBoxWidget::onNewGTP() {
const Point2 center = view->getScaler().getCenter();
Floorplan::GroundTruthPoint* gtp = new Floorplan::GroundTruthPoint(
0, Point2(center.x, center.y)
);
MMFloorGroundTruthPoints* gtps = (MMFloorGroundTruthPoints*) curLayer;
gtps->createGroundTruthPoint(gtp);
}
void ToolBoxWidget::onNewImage() {
const Point2 center = view->getScaler().getCenter();

View File

@@ -43,6 +43,7 @@ private:
QPushButton* btnWifi;
QPushButton* btnBeacon;
QPushButton* btnPOI;
QPushButton* btnGTP;
QPushButton* btnImage;
@@ -60,6 +61,7 @@ private slots:
void onNewAccessPoint();
void onNewBeacon();
void onNewPOI();
void onNewGTP();
void onNewImage();

View File

@@ -14,5 +14,6 @@
<file>res/icons/door.svg</file>
<file>res/icons/cursor.svg</file>
<file>res/icons/elevator.svg</file>
<file>res/icons/gtp.svg</file>
</qresource>
</RCC>

77
res/icons/gtp.svg Normal file
View File

@@ -0,0 +1,77 @@
<?xml version="1.0" encoding="iso-8859-1"?>
<!-- Generator: Adobe Illustrator 19.0.0, SVG Export Plug-In . SVG Version: 6.00 Build 0) -->
<svg version="1.1" id="Layer_1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px"
viewBox="0 0 512 512" style="enable-background:new 0 0 512 512;" xml:space="preserve">
<g>
<g>
<path d="M385.838,42.607l-18.909-18.91c-1.912-1.912-4.507-2.987-7.212-2.987c-2.705,0-5.299,1.075-7.212,2.987l-41.534,41.534
l-0.962-0.962c-1.912-1.912-4.507-2.987-7.212-2.987c-2.705,0-5.298,1.075-7.212,2.987l-8.459,8.459l-0.719-0.719
c-5.912-5.914-13.773-9.169-22.134-9.169c-8.361,0-16.223,3.256-22.135,9.168l-58.208,58.208c-3.983,3.983-3.983,10.441,0,14.425
c1.992,1.991,4.602,2.987,7.212,2.987s5.22-0.996,7.212-2.987l58.208-58.208c2.06-2.06,4.798-3.194,7.712-3.194
c2.912,0,5.65,1.134,7.712,3.194l0.719,0.719L55.295,304.559c-0.95,0.951-1.702,2.078-2.214,3.319L28.268,367.95
c-1.574,3.808-0.701,8.191,2.214,11.106c1.951,1.951,4.56,2.986,7.215,2.986c1.311,0,2.632-0.252,3.891-0.773l60.072-24.813
c1.241-0.512,2.368-1.265,3.319-2.214l240.289-240.289c3.983-3.983,3.983-10.441,0-14.425l-0.963-0.963l41.533-41.534
C389.821,53.049,389.821,46.591,385.838,42.607z M91.994,338.38l-35.498,14.662l14.662-35.498L302.796,85.907l20.836,20.836
L91.994,338.38z M329.881,84.142l-4.486-4.486l34.321-34.321l4.486,4.486L329.881,84.142z"/>
</g>
</g>
<g>
<g>
<path d="M506.555,135.251c-3.347-1.764-7.396-1.531-10.519,0.61L4.435,472.678c-3.687,2.526-5.299,7.161-3.978,11.43
c1.323,4.271,5.273,7.182,9.743,7.182h491.601c5.632,0,10.199-4.567,10.199-10.199V144.274
C511.999,140.489,509.903,137.016,506.555,135.251z M491.601,470.892h-46.093v-9.421c0-5.632-4.567-10.199-10.199-10.199
c-5.632,0-10.199,4.567-10.199,10.199v9.421h-83.88v-9.421c0-5.632-4.567-10.199-10.199-10.199s-10.199,4.567-10.199,10.199v9.421
h-83.88v-9.421c0-5.632-4.567-10.199-10.199-10.199c-5.632,0-10.199,4.567-10.199,10.199v9.421h-83.88v-9.421
c0-5.632-4.567-10.199-10.199-10.199c-5.632,0-10.199,4.567-10.199,10.199v9.421H43.13l448.47-307.267V470.892z"/>
</g>
</g>
<g>
<g>
<path d="M440.064,260.857c-3.349-1.763-7.397-1.531-10.521,0.61L218.319,406.186c-3.687,2.527-5.299,7.161-3.978,11.431
s5.272,7.181,9.742,7.181h211.225c5.632,0,10.199-4.567,10.199-10.199V269.881C445.507,266.096,443.412,262.623,440.064,260.857z
M425.108,404.4H257.014l168.094-115.168V404.4z"/>
</g>
</g>
<g>
<g>
<path d="M473.242,197.733c-5.632,0-10.199,4.567-10.199,10.199v60.175c0,5.633,4.566,10.199,10.199,10.199
c5.632,0,10.199-4.567,10.199-10.199v-60.175C483.441,202.3,478.874,197.733,473.242,197.733z"/>
</g>
</g>
<g>
<g>
<path d="M473.242,287.485c-5.632,0-10.199,4.567-10.199,10.199v8.159c0,5.633,4.566,10.199,10.199,10.199
c5.632,0,10.199-4.567,10.199-10.199v-8.159C483.441,292.053,478.874,287.485,473.242,287.485z"/>
</g>
</g>
<g>
</g>
<g>
</g>
<g>
</g>
<g>
</g>
<g>
</g>
<g>
</g>
<g>
</g>
<g>
</g>
<g>
</g>
<g>
</g>
<g>
</g>
<g>
</g>
<g>
</g>
<g>
</g>
<g>
</g>
</svg>

After

Width:  |  Height:  |  Size: 3.0 KiB