Merge branch 'master' of https://git.frank-ebner.de/FHWS/IndoorMap
This commit is contained in:
@@ -22,12 +22,12 @@ INCLUDEPATH += \
|
||||
|
||||
|
||||
SOURCES += \
|
||||
lib/gpc/gpc.cpp \
|
||||
main.cpp \
|
||||
MainWindow.cpp \
|
||||
lib/gpc/gpc.cpp \
|
||||
main.cpp \
|
||||
MainWindow.cpp \
|
||||
MainController.cpp \
|
||||
mapview/2D/tools/ToolSelector.cpp \
|
||||
mapview/2D/tools/Tool.cpp \
|
||||
mapview/2D/tools/ToolSelector.cpp \
|
||||
mapview/2D/tools/Tool.cpp \
|
||||
mapview/MapView2D.cpp \
|
||||
params/ElementParamWidget.cpp \
|
||||
params/LayerParamWidget.cpp \
|
||||
@@ -35,7 +35,7 @@ SOURCES += \
|
||||
params/ToolBox.cpp \
|
||||
mapview/model/MapModel.cpp \
|
||||
tree/MapTreeModel.cpp \
|
||||
mapview/3D/MapView3D.cpp \
|
||||
mapview/3D/MapView3D.cpp \
|
||||
params/StairBuilder.cpp \
|
||||
mapview/2D/tools/Tools.cpp \
|
||||
params/LayerTree.cpp \
|
||||
@@ -62,24 +62,24 @@ HEADERS += MainWindow.h \
|
||||
mapview/model/IHasName.h \
|
||||
mapview/model/IHasObstacleType.h \
|
||||
mapview/model/IHasPosition3D.h \
|
||||
mapview/2D/MV2DElementFloorObstacleLine.h \
|
||||
mapview/2D/MV2DElement.h \
|
||||
mapview/2D/MV2DElementFloorOutlinePolygon.h \
|
||||
mapview/2D/MV2DElementBeacon.h \
|
||||
mapview/2D/MV2DElementAccessPoint.h \
|
||||
mapview/2D/MV2DElementFloorObstacleCircle.h \
|
||||
mapview/2D/MV2DElementFloorObstacleDoor.h \
|
||||
mapview/2D/MapViewElementHelper.h \
|
||||
mapview/2D/MV2DElementFloorUnderlay.h \
|
||||
mapview/2D/MV2DElementPOI.h \
|
||||
mapview/2D/MV2DElementStair.h \
|
||||
mapview/2D/tools/ToolMoveMap.h \
|
||||
mapview/2D/tools/Tools.h \
|
||||
mapview/2D/tools/ToolRuler.h \
|
||||
mapview/2D/tools/ToolMapZoom.h \
|
||||
mapview/2D/tools/ToolSelector.h \
|
||||
mapview/2D/tools/ToolMapGrid.h \
|
||||
mapview/2D/tools/Tool.h \
|
||||
mapview/2D/MV2DElementFloorObstacleLine.h \
|
||||
mapview/2D/MV2DElement.h \
|
||||
mapview/2D/MV2DElementFloorOutlinePolygon.h \
|
||||
mapview/2D/MV2DElementBeacon.h \
|
||||
mapview/2D/MV2DElementAccessPoint.h \
|
||||
mapview/2D/MV2DElementFloorObstacleCircle.h \
|
||||
mapview/2D/MV2DElementFloorObstacleDoor.h \
|
||||
mapview/2D/MapViewElementHelper.h \
|
||||
mapview/2D/MV2DElementFloorUnderlay.h \
|
||||
mapview/2D/MV2DElementPOI.h \
|
||||
mapview/2D/MV2DElementStair.h \
|
||||
mapview/2D/tools/ToolMoveMap.h \
|
||||
mapview/2D/tools/Tools.h \
|
||||
mapview/2D/tools/ToolRuler.h \
|
||||
mapview/2D/tools/ToolMapZoom.h \
|
||||
mapview/2D/tools/ToolSelector.h \
|
||||
mapview/2D/tools/ToolMapGrid.h \
|
||||
mapview/2D/tools/Tool.h \
|
||||
mapview/model/MMFloorObstacleCircle.h \
|
||||
mapview/model/MMFloorObstacleLine.h \
|
||||
mapview/model/MMFloorOutlinePolygon.h \
|
||||
@@ -109,7 +109,7 @@ HEADERS += MainWindow.h \
|
||||
mapview/3D/misc/Polygon.h \
|
||||
mapview/grid/MapView3DGrid.h \
|
||||
mapview/grid/MapModelGrid.h \
|
||||
mapview/3DGrid/GridModel.h \
|
||||
mapview/3DGrid/GridModel.h \
|
||||
mapview/3DGrid/GridRenderer.h \
|
||||
mapview/3DGrid/MyNode.h \
|
||||
mapview/3D/MV3DElementStair.h \
|
||||
@@ -126,8 +126,8 @@ HEADERS += MainWindow.h \
|
||||
mapview/3D/misc/Plane.h \
|
||||
mapview/elements/HasMoveableNodes.h \
|
||||
mapview/2D/MapView2D.h \
|
||||
mapview/2D/Painter.h \
|
||||
mapview/2D/Scaler.h \
|
||||
mapview/2D/Painter.h \
|
||||
mapview/2D/Scaler.h \
|
||||
mapview/2D/MV2DElementElevator.h \
|
||||
mapview/model/MMFloorElevators.h \
|
||||
mapview/model/MMFloorElevator.h \
|
||||
@@ -144,7 +144,10 @@ HEADERS += MainWindow.h \
|
||||
mapview/model/MMFloorFingerprints.h \
|
||||
mapview/model/MMFloorFingerprintLocation.h \
|
||||
mapview/2D/MV2DElementFingerprintLocation.h \
|
||||
mapview/3D/MV3DElementFingerprintLocation.h
|
||||
mapview/3D/MV3DElementFingerprintLocation.h \
|
||||
mapview/model/MMFloorGroundTruthPoints.h \
|
||||
mapview/model/MMFloorGroundTruthPoint.h \
|
||||
mapview/2D/MV2DElementGroundTruthPoint.h
|
||||
|
||||
|
||||
FORMS += MainWindow.ui
|
||||
|
||||
@@ -27,6 +27,7 @@
|
||||
|
||||
|
||||
|
||||
|
||||
MainController::MainController() {
|
||||
|
||||
// Floorplan::Meta* meta = new Floorplan::Meta();
|
||||
@@ -93,101 +94,94 @@ MainController::MainController() {
|
||||
connect(mw, &MainWindow::onGridShowEdges, [&] (const bool show) {mw->getMapView3D()->getGridRenderer()->setShowEdges(show);} );
|
||||
|
||||
|
||||
mapModel->load("../IndoorMap/maps/SHL28.xml");
|
||||
mapModel->load("../IndoorMap/maps/SHL32.xml");
|
||||
//mapModel->resize(0.983, 0.983, 1, -0.2, -0.3, 0);
|
||||
|
||||
|
||||
//mapModel->load("../IndoorMap/maps/test.xml");
|
||||
//mapModel->load("../IndoorMap/maps/APs.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("/mnt/data/workspaces/IPIN2016/IPIN2016/competition/maps/UAH/UAH9.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("/mnt/data/workspaces/Indoor/tests/data/WalkHeadingMap.xml");
|
||||
//mapModel->load("/mnt/data/workspaces/IPIN2016/IPIN2016/competition/maps/test.xml");
|
||||
//mapModel->load("/mnt/vm/workspace/IRGame/IndoorServer/maps/map6.xml");
|
||||
//mapModel->load("/mnt/vm/workspace/IRGame/IndoorServer/maps/keller1.xml");
|
||||
//mapModel->load("/mnt/vm/workspace/IRGame/IndoorServer/maps/wohnung4.xml");
|
||||
|
||||
//mapModel->startEmpty();
|
||||
// mapModel->startEmpty();
|
||||
|
||||
}
|
||||
|
||||
|
||||
void MainController::onLayerChanged(MapLayer* layer) {
|
||||
(void) layer;
|
||||
mw->getMapView2D()->update();
|
||||
mw->getMapView3D()->update();
|
||||
(void) layer;
|
||||
mw->getMapView2D()->update();
|
||||
mw->getMapView3D()->update();
|
||||
}
|
||||
|
||||
void MainController::onLayerElementAdded(MapLayer* layer, MapModelElement* elem) {
|
||||
(void) layer;
|
||||
mapSelector->focus(mw->getMapView2D(), elem);
|
||||
(void) layer;
|
||||
mapSelector->focus(mw->getMapView2D(), elem);
|
||||
}
|
||||
|
||||
void MainController::onLayerElementRemoved(MapLayer* layer, const MapModelElement* elem) {
|
||||
(void) layer;
|
||||
(void) elem;
|
||||
(void) layer;
|
||||
(void) elem;
|
||||
}
|
||||
|
||||
void MainController::onLayerVisibilityChanged(MapLayer *layer, const bool visible) {
|
||||
(void) layer;
|
||||
(void) visible;
|
||||
(void) layer;
|
||||
(void) visible;
|
||||
}
|
||||
|
||||
void MainController::onShow3DFloorplan() {
|
||||
mw->getMapView3D()->showFloorplan();
|
||||
mw->getMapView3D()->showFloorplan();
|
||||
}
|
||||
|
||||
void MainController::onShow3DGrid() {
|
||||
mw->getMapView3D()->showGrid();
|
||||
mw->getMapView3D()->showGrid();
|
||||
}
|
||||
|
||||
void MainController::layerSelected(QModelIndex idx) {
|
||||
mw->getMapView2D()->layerChange();
|
||||
MapLayer* ml = static_cast<MapLayer*>(idx.internalPointer());
|
||||
mapModel->setSelectedLayer(ml);
|
||||
mw->getMapView2D()->layerChange();
|
||||
mw->getMapView3D()->layerChange();
|
||||
mw->getLayerParamWidget()->setElement(ml);
|
||||
mw->getToolBoxWidget()->setSelectedLayer(ml);
|
||||
mw->getMapView2D()->layerChange();
|
||||
MapLayer* ml = static_cast<MapLayer*>(idx.internalPointer());
|
||||
mapModel->setSelectedLayer(ml);
|
||||
mw->getMapView2D()->layerChange();
|
||||
mw->getMapView3D()->layerChange();
|
||||
mw->getLayerParamWidget()->setElement(ml);
|
||||
mw->getToolBoxWidget()->setSelectedLayer(ml);
|
||||
}
|
||||
|
||||
void MainController::curMapElementChanged() {
|
||||
mw->getElementParamWidget()->refresh();
|
||||
mw->getElementParamWidget()->refresh();
|
||||
}
|
||||
|
||||
void MainController::mapElementSelected(MapModelElement* el) {
|
||||
mw->getElementParamWidget()->setElement(el);
|
||||
mw->getElementParamWidget()->setElement(el);
|
||||
}
|
||||
|
||||
void MainController::onMapModelAboutToReset() {
|
||||
mw->getLayerParamWidget()->setElement(nullptr);
|
||||
mw->getToolBoxWidget()->setSelectedLayer(nullptr);
|
||||
mw->getMapView2D()->update();
|
||||
mw->getLayerParamWidget()->setElement(nullptr);
|
||||
mw->getToolBoxWidget()->setSelectedLayer(nullptr);
|
||||
mw->getMapView2D()->update();
|
||||
}
|
||||
|
||||
void MainController::onMapModelNeedsRepaint() {
|
||||
mw->getMapView2D()->update();
|
||||
mw->getMapView2D()->update();
|
||||
}
|
||||
|
||||
void MainController::onMapModelReset() {
|
||||
mw->getTree()->expandAll();
|
||||
mw->getTree()->expandAll();
|
||||
}
|
||||
|
||||
void MainController::onLoad() {
|
||||
|
||||
QString file = QFileDialog::getOpenFileName(mw, "open a map");
|
||||
if (file != "") {
|
||||
mapModel->load(file.toStdString());
|
||||
}
|
||||
QString file = QFileDialog::getOpenFileName(mw, "open a map");
|
||||
if (file != "") {
|
||||
mapModel->load(file.toStdString());
|
||||
}
|
||||
}
|
||||
|
||||
void MainController::onSave() {
|
||||
|
||||
QString file = QFileDialog::getSaveFileName(mw, "save the map");
|
||||
if (file != "") {
|
||||
mapModel->save(file.toStdString());
|
||||
}
|
||||
|
||||
QString file = QFileDialog::getSaveFileName(mw, "save the map");
|
||||
if (file != "") {
|
||||
mapModel->save(file.toStdString());
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
@@ -53,13 +53,14 @@ public:
|
||||
switch (fo.method) {
|
||||
case Floorplan::OutlineMethod::ADD:
|
||||
brush.setStyle(Qt::BrushStyle::SolidPattern);
|
||||
brush.setColor(QColor(0,0,0,24));
|
||||
brush.setColor( fo.outdoor ? QColor(0,255,0,32) : QColor(0,0,0,24) ); // outdoor = green
|
||||
break;
|
||||
case Floorplan::OutlineMethod::REMOVE:
|
||||
brush.setStyle(Qt::BrushStyle::DiagCrossPattern);
|
||||
brush.setColor(QColor(0,0,0));
|
||||
break;
|
||||
default:
|
||||
// should not happen
|
||||
brush.setStyle(Qt::BrushStyle::SolidPattern);
|
||||
brush.setColor(QColor(255,0,0));
|
||||
}
|
||||
|
||||
@@ -92,7 +92,7 @@ public:
|
||||
|
||||
|
||||
// if the to-be-displayed image is smaller than the input-one, use a pre-computed downscaled version
|
||||
if (scaledArea < origArea) {
|
||||
if (scaledArea < origArea*0.75) {
|
||||
// does the cached downscaled image needs rebuild? (size changed)
|
||||
if (imgScaled.width() != sw || imgScaled.height() != sh) {
|
||||
imgScaled = img.scaled(sw, sh, Qt::IgnoreAspectRatio, Qt::SmoothTransformation);
|
||||
|
||||
119
mapview/2D/MV2DElementGroundTruthPoint.h
Normal file
119
mapview/2D/MV2DElementGroundTruthPoint.h
Normal 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 */
|
||||
ClickDist getMinDistanceXY(const Point2 p) const override {
|
||||
return ClickDist(p.getDistance(gtp->pos), ClickDistType::DIRECT);
|
||||
}
|
||||
|
||||
/** 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
|
||||
@@ -299,12 +299,47 @@ private:
|
||||
return true;
|
||||
}
|
||||
|
||||
if (e->key() == Qt::Key_Up || e->key() == Qt::Key_Down || e->key() == Qt::Key_Left || e->key() == Qt::Key_Right) {
|
||||
moveNodes(m, focused, e->key());
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
return false;
|
||||
|
||||
}
|
||||
|
||||
void moveNodes(MapView2D* v, MapModelElement* focused, const int key) {
|
||||
|
||||
MV2DElement* me = focused->getMV2D();
|
||||
if (!me) {return;}
|
||||
|
||||
HasMoveableNodes* elem = dynamic_cast<HasMoveableNodes*>(me);
|
||||
if (!elem) {return;}
|
||||
|
||||
// no node selected? -> done
|
||||
if (elem->getSelectedNode() == -1) {return;}
|
||||
|
||||
// get current value
|
||||
MoveableNode& node = elem->getMoveableNodes()[elem->getSelectedNode()];
|
||||
Point2 pos = node.pos;
|
||||
|
||||
// adjust the node
|
||||
switch(key) {
|
||||
case Qt::Key_Up: pos.y += 0.1; break;
|
||||
case Qt::Key_Down: pos.y -= 0.1; break;
|
||||
case Qt::Key_Left: pos.x -= 0.1; break;
|
||||
case Qt::Key_Right: pos.x += 0.1; break;
|
||||
}
|
||||
|
||||
// snap the position
|
||||
pos = v->getScaler().snap(pos);
|
||||
|
||||
// move
|
||||
elem->onNodeMove(v, elem->getSelectedNode(), pos);
|
||||
|
||||
}
|
||||
|
||||
signals:
|
||||
|
||||
/** map element was selected */
|
||||
|
||||
@@ -21,18 +21,25 @@ private:
|
||||
|
||||
struct Color {
|
||||
float r,g,b;
|
||||
Color() : r(1), g(0), b(0) {;}
|
||||
Color(float r, float g, float b) : r(r), g(g), b(b) {;}
|
||||
};
|
||||
|
||||
Color colors[4] = {
|
||||
Color(0.3, 0.3, 0.3), Color(0,0,1), Color(0,0,1), Color(0,0.65,0)
|
||||
};
|
||||
/** node color depending on the node's type. see ctor */
|
||||
Color colors[200];
|
||||
|
||||
public:
|
||||
|
||||
/** ctor */
|
||||
GridRenderer() {
|
||||
;
|
||||
|
||||
colors[GridNode::TYPE_FLOOR] = Color(0.4, 0.4, 0.4);
|
||||
colors[GridNode::TYPE_STAIR] = Color(0,0,1);
|
||||
colors[GridNode::TYPE_ELEVATOR] = Color(0,0,1);
|
||||
colors[GridNode::TYPE_DOOR] = Color(0.0, 0.0, 0.0);
|
||||
|
||||
colors[GridNode::TYPE_OUTDOOR] = Color(0.0, 0.5, 0.0);
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
||||
@@ -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
|
||||
|
||||
@@ -11,6 +11,7 @@
|
||||
#include "MMFloorPOIs.h"
|
||||
#include "MMFloorStairs.h"
|
||||
#include "MMFloorElevators.h"
|
||||
#include "MMFloorGroundTruthPoints.h"
|
||||
|
||||
#include "IHasParams.h"
|
||||
|
||||
@@ -45,6 +46,7 @@ public:
|
||||
new MMFloorPOIs(this, floor);
|
||||
new MMFloorStairs(this, floor);
|
||||
new MMFloorElevators(this, floor);
|
||||
new MMFloorGroundTruthPoints(this, floor);
|
||||
|
||||
}
|
||||
|
||||
|
||||
61
mapview/model/MMFloorGroundTruthPoint.h
Normal file
61
mapview/model/MMFloorGroundTruthPoint.h
Normal 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
|
||||
46
mapview/model/MMFloorGroundTruthPoints.h
Normal file
46
mapview/model/MMFloorGroundTruthPoints.h
Normal 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) {
|
||||
addElement(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
|
||||
addElement(new MMFloorGroundTruthPoint(this, floor, gtp));
|
||||
|
||||
}
|
||||
|
||||
std::string getLayerName() const override {return "GroundTruthPoints";}
|
||||
|
||||
};
|
||||
|
||||
#endif // MMFLOORGROUNDTRUTHPOINTS_H
|
||||
@@ -39,12 +39,13 @@ public:
|
||||
//MV3DElement* getMV3D() const override {return (MV3DElement*) &mv3d;}
|
||||
|
||||
virtual int getNumParams() const override {
|
||||
return 1;
|
||||
return 2;
|
||||
}
|
||||
|
||||
virtual Param getParamDesc(const int idx) const override {
|
||||
switch(idx) {
|
||||
case 0: return Param("name", ParamType::STRING);
|
||||
case 1: return Param("outdoor", ParamType::BOOL);
|
||||
}
|
||||
throw 1;
|
||||
}
|
||||
@@ -52,6 +53,7 @@ public:
|
||||
virtual ParamValue getParamValue(const int idx) const override {
|
||||
switch(idx) {
|
||||
case 0: return fo->name;
|
||||
case 1: return fo->outdoor;
|
||||
}
|
||||
throw 1;
|
||||
}
|
||||
@@ -59,6 +61,7 @@ public:
|
||||
virtual void setParamValue(const int idx, const ParamValue& val) const override {
|
||||
switch(idx) {
|
||||
case 0: fo->name = val.toString(); break;
|
||||
case 1: fo->outdoor = val.toBool(); break;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@@ -24,6 +24,7 @@ enum class MapLayerType {
|
||||
FLOOR_UNDERLAYS,
|
||||
FLOOR_POIS,
|
||||
FLOOR_STAIRS,
|
||||
FLOOR_GROUND_TRUTH_POINTS
|
||||
};
|
||||
|
||||
|
||||
|
||||
@@ -86,6 +86,82 @@ public:
|
||||
|
||||
}
|
||||
|
||||
float snap(const float val) {
|
||||
const float s = 0.1;
|
||||
return std::round(val / s) * s;
|
||||
}
|
||||
|
||||
/** resize everything within the floorplay by the given factor */
|
||||
void resize(const float sx, const float sy, const float sz, const float ox, const float oy, const float oz) {
|
||||
|
||||
for (Floorplan::Floor* f : im->floors) {
|
||||
f->atHeight = snap(f->atHeight * sz);
|
||||
f->height = snap(f->height * sz);
|
||||
for (Floorplan::FloorOutlinePolygon* poly : f->outline) {
|
||||
for (Point2& p : poly->poly.points) {
|
||||
p.x = snap(p.x * sx + ox);
|
||||
p.y = snap(p.y * sy + oy);
|
||||
}
|
||||
}
|
||||
for (Floorplan::AccessPoint* ap : f->accesspoints) {
|
||||
ap->pos.x = snap(ap->pos.x * sx + ox);
|
||||
ap->pos.y = snap(ap->pos.y * sy + oy);
|
||||
ap->pos.z = snap(ap->pos.z * sz + oz);
|
||||
}
|
||||
for (Floorplan::Beacon* b : f->beacons) {
|
||||
b->pos.x = snap(b->pos.x * sx + ox);
|
||||
b->pos.y = snap(b->pos.y * sy + oy);
|
||||
b->pos.z = snap(b->pos.z * sz + oz);
|
||||
}
|
||||
for (Floorplan::POI* p : f->pois) {
|
||||
p->pos.x = snap(p->pos.x * sx + ox);
|
||||
p->pos.y = snap(p->pos.y * sy + oy);
|
||||
}
|
||||
for (Floorplan::FingerprintLocation* fpl : f->fpLocations) {
|
||||
fpl->posOnFloor.x = snap(fpl->posOnFloor.x * sx + ox);
|
||||
fpl->posOnFloor.y = snap(fpl->posOnFloor.y * sy + oy);
|
||||
fpl->heightAboveFloor = snap(fpl->heightAboveFloor * sz + oz);
|
||||
}
|
||||
for (Floorplan::FloorObstacle* o : f->obstacles) {
|
||||
Floorplan::FloorObstacleLine* line = dynamic_cast<Floorplan::FloorObstacleLine*>(o);
|
||||
Floorplan::FloorObstacleDoor* door = dynamic_cast<Floorplan::FloorObstacleDoor*>(o);
|
||||
if (line) {
|
||||
line->from.x = snap(line->from.x * sx + ox);
|
||||
line->from.y = snap(line->from.y * sy + oy);
|
||||
line->to.x = snap(line->to.x * sx + ox);
|
||||
line->to.y = snap(line->to.y * sy + oy);
|
||||
} else if (door) {
|
||||
door->from.x = snap(door->from.x * sx + ox);
|
||||
door->from.y = snap(door->from.y * sy + oy);
|
||||
door->to.x = snap(door->to.x * sx + ox);
|
||||
door->to.y = snap(door->to.y * sy + oy);
|
||||
}
|
||||
}
|
||||
for (Floorplan::Stair* s : f->stairs) {
|
||||
Floorplan::StairFreeform* stair = dynamic_cast<Floorplan::StairFreeform*>(s);
|
||||
for (Floorplan::StairPart& sp : stair->parts) {
|
||||
sp.width = snap(sp.width * sx);
|
||||
sp.end.x = snap(sp.end.x * sx + ox);
|
||||
sp.end.y = snap(sp.end.y * sy + oy);
|
||||
sp.end.z = snap(sp.end.z * sz + oz);
|
||||
sp.start.x = snap(sp.start.x * sx + ox);
|
||||
sp.start.y = snap(sp.start.y * sy + oy);
|
||||
sp.start.z = snap(sp.start.z * sz + oz);
|
||||
}
|
||||
}
|
||||
for (Floorplan::Elevator* e : f->elevators) {
|
||||
e->center.x = snap(e->center.x * sx + ox);
|
||||
e->center.y = snap(e->center.y * sy + oy);
|
||||
e->width = snap(e->width * sx);
|
||||
e->depth = snap(e->depth * sx);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
|
||||
|
||||
void onLayerChanged(MapLayer* layer) override {
|
||||
for (MapModelListener* l : listeners) {l->onLayerChanged(layer);}
|
||||
}
|
||||
|
||||
@@ -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 "../mapview/2D/tools/ToolMeasure.h"
|
||||
|
||||
@@ -117,6 +118,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);
|
||||
|
||||
@@ -142,6 +149,7 @@ void ToolBoxWidget::setSelectedLayer(MapLayer *ml) {
|
||||
btnBeacon->setEnabled(ml && (ml->getLayerType() == MapLayerType::FLOOR_BEACONS));
|
||||
btnFingerprintLocation->setEnabled(ml && (ml->getLayerType() == MapLayerType::FLOOR_FINGERPRINTS));
|
||||
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));
|
||||
|
||||
@@ -495,6 +503,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();
|
||||
|
||||
@@ -47,6 +47,7 @@ private:
|
||||
QPushButton* btnBeacon;
|
||||
QPushButton* btnFingerprintLocation;
|
||||
QPushButton* btnPOI;
|
||||
QPushButton* btnGTP;
|
||||
|
||||
QPushButton* btnImage;
|
||||
|
||||
@@ -66,6 +67,7 @@ private slots:
|
||||
void onNewBeacon();
|
||||
void onNewFingerprintLocation();
|
||||
void onNewPOI();
|
||||
void onNewGTP();
|
||||
|
||||
void onNewImage();
|
||||
|
||||
|
||||
1
res.qrc
1
res.qrc
@@ -18,5 +18,6 @@
|
||||
<file>res/icons/remove.svg</file>
|
||||
<file>res/icons/ruler.svg</file>
|
||||
<file>res/icons/fingerprint.svg</file>
|
||||
<file>res/icons/gtp.svg</file>
|
||||
</qresource>
|
||||
</RCC>
|
||||
|
||||
77
res/icons/gtp.svg
Normal file
77
res/icons/gtp.svg
Normal 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 |
Reference in New Issue
Block a user