From e96b743ef967a0823e93fd65487f66b6b5d1c763 Mon Sep 17 00:00:00 2001 From: Lionel Heng Date: Sun, 5 Dec 2010 20:49:20 +0100 Subject: [PATCH] Fixed coordinate system issue in waypoint management for 3D view. --- src/ui/WaypointList.cc | 5 ++- src/ui/map3D/Pixhawk3DWidget.cc | 54 ++++++++++++++++++++++++--------- 2 files changed, 41 insertions(+), 18 deletions(-) diff --git a/src/ui/WaypointList.cc b/src/ui/WaypointList.cc index 5478e2a4e..358668733 100644 --- a/src/ui/WaypointList.cc +++ b/src/ui/WaypointList.cc @@ -199,10 +199,9 @@ void WaypointList::add() } else { - - //isLocalWP = true; - Waypoint *wp = new Waypoint(0, 1.1, 1.1, -0.8, 0.0, true, true, 0.15, 2000); + Waypoint *wp = new Waypoint(0, uas->getLongitude(), uas->getLatitude(), uas->getAltitude(), + 0.0, true, true, 0.15, 2000); uas->getWaypointManager().addWaypoint(wp); diff --git a/src/ui/map3D/Pixhawk3DWidget.cc b/src/ui/map3D/Pixhawk3DWidget.cc index 5d25e484b..ab7ba5a55 100644 --- a/src/ui/map3D/Pixhawk3DWidget.cc +++ b/src/ui/map3D/Pixhawk3DWidget.cc @@ -235,15 +235,23 @@ Pixhawk3DWidget::insertWaypoint(void) { if (uas) { + double latitude = uas->getLatitude(); + double longitude = uas->getLongitude(); double altitude = uas->getAltitude(); + double x, y; + QString utmZone; + Imagery::LLtoUTM(uas->getLatitude(), uas->getLongitude(), x, y, utmZone); std::pair cursorWorldCoords = getGlobalCursorPosition(getMouseX(), getMouseY(), altitude); + Imagery::UTMtoLL(cursorWorldCoords.first, cursorWorldCoords.second, utmZone, + latitude, longitude); + Waypoint* wp = new Waypoint(0, - cursorWorldCoords.first, - cursorWorldCoords.second, - -altitude); + longitude, + latitude, + altitude); uas->getWaypointManager().addWaypoint(wp); } } @@ -259,17 +267,25 @@ Pixhawk3DWidget::setWaypoint(void) { if (uas) { + double latitude = uas->getLatitude(); + double longitude = uas->getLongitude(); double altitude = uas->getAltitude(); + double x, y; + QString utmZone; + Imagery::LLtoUTM(uas->getLatitude(), uas->getLongitude(), x, y, utmZone); std::pair cursorWorldCoords = getGlobalCursorPosition(getMouseX(), getMouseY(), altitude); + Imagery::UTMtoLL(cursorWorldCoords.first, cursorWorldCoords.second, utmZone, + latitude, longitude); + const QVector waypoints = uas->getWaypointManager().getWaypointList(); Waypoint* waypoint = waypoints.at(selectedWpIndex); - waypoint->setX(cursorWorldCoords.first); - waypoint->setY(cursorWorldCoords.second); - waypoint->setZ(-altitude); + waypoint->setX(longitude); + waypoint->setY(latitude); + waypoint->setZ(altitude); } } @@ -294,10 +310,10 @@ Pixhawk3DWidget::setWaypointAltitude(void) double newAltitude = QInputDialog::getDouble(this, tr("Set altitude of waypoint %1").arg(selectedWpIndex), - tr("Altitude (m):"), -waypoint->getZ(), -1000.0, 1000.0, 1, &ok); + tr("Altitude (m):"), waypoint->getZ(), -1000.0, 1000.0, 1, &ok); if (ok) { - waypoint->setZ(-newAltitude); + waypoint->setZ(newAltitude); } } } @@ -1049,7 +1065,7 @@ Pixhawk3DWidget::updateWaypoints(void) osg::ref_ptr sd = new osg::ShapeDrawable; osg::ref_ptr cylinder = - new osg::Cylinder(osg::Vec3d(0.0, 0.0, - wp->getZ() / 2.0), + new osg::Cylinder(osg::Vec3d(0.0, 0.0, wp->getZ() / 2.0), wp->getOrbit(), fabs(wp->getZ())); @@ -1072,14 +1088,21 @@ Pixhawk3DWidget::updateWaypoints(void) sprintf(wpLabel, "wp%d", i); geode->setName(wpLabel); + double wpX, wpY; + Imagery::LLtoUTM(wp->getY(), wp->getX(), wpX, wpY, utmZone); + if (i < list.size() - 1) { + double nextWpX, nextWpY; + Imagery::LLtoUTM(list.at(i+1)->getY(), list.at(i+1)->getX(), + nextWpX, nextWpY, utmZone); + osg::ref_ptr geometry = new osg::Geometry; osg::ref_ptr vertices = new osg::Vec3dArray; - vertices->push_back(osg::Vec3d(0.0, 0.0, -wp->getZ())); - vertices->push_back(osg::Vec3d(list.at(i+1)->getY() - wp->getY(), - list.at(i+1)->getX() - wp->getX(), - -list.at(i+1)->getZ())); + vertices->push_back(osg::Vec3d(0.0, 0.0, wp->getZ())); + vertices->push_back(osg::Vec3d(nextWpY - wpY, + nextWpX - wpX, + list.at(i+1)->getZ())); geometry->setVertexArray(vertices); osg::ref_ptr colors = new osg::Vec4Array; @@ -1092,6 +1115,7 @@ Pixhawk3DWidget::updateWaypoints(void) osg::ref_ptr linewidth(new osg::LineWidth()); linewidth->setWidth(2.0f); geometry->getOrCreateStateSet()->setAttributeAndModes(linewidth, osg::StateAttribute::ON); + geometry->getOrCreateStateSet()->setMode(GL_LIGHTING, osg::StateAttribute::OFF); geode->addDrawable(geometry); } @@ -1099,8 +1123,8 @@ Pixhawk3DWidget::updateWaypoints(void) osg::ref_ptr pat = new osg::PositionAttitudeTransform; - pat->setPosition(osg::Vec3d(wp->getY() - robotY, - wp->getX() - robotX, + pat->setPosition(osg::Vec3d(wpY - robotY, + wpX - robotX, robotZ)); waypointsNode->addChild(pat); -- 2.22.0