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
|
// SPDX-License-Identifier: LGPL-2.1-or-later
//
// SPDX-FileCopyrightText: 2014 Bernhard Beschow <bbeschow@cs.tu-berlin.de>
//
#include "GnomonicProjection.h"
#include "TestUtils.h"
#include "ViewportParams.h"
namespace Marble
{
class GnomonicProjectionTest : public QObject
{
Q_OBJECT
private Q_SLOTS:
void screenCoordinatesOfCenter_data();
void screenCoordinatesOfCenter();
};
void GnomonicProjectionTest::screenCoordinatesOfCenter_data()
{
ViewportParams gnomonic;
gnomonic.setProjection(Gnomonic);
QTest::addColumn<QPoint>("screenCoordinates");
QTest::addColumn<GeoDataCoordinates>("expected");
addRow() << QPoint(5, 15) << GeoDataCoordinates(-45, 72.5536, 0, GeoDataCoordinates::Degree);
addRow() << QPoint(15, 5) << GeoDataCoordinates(135, 72.5536, 0, GeoDataCoordinates::Degree);
}
void GnomonicProjectionTest::screenCoordinatesOfCenter()
{
QFETCH(QPoint, screenCoordinates);
QFETCH(GeoDataCoordinates, expected);
ViewportParams viewport;
viewport.setProjection(Gnomonic);
viewport.setRadius(180 / 4); // for easy mapping of lon <-> x
viewport.setSize(QSize(20, 20));
viewport.centerOn(0 * DEG2RAD, 90 * DEG2RAD);
{
qreal lon, lat;
const bool retval = viewport.geoCoordinates(screenCoordinates.x(), screenCoordinates.y(), lon, lat, GeoDataCoordinates::Degree);
QVERIFY(retval); // we want valid coordinates
QCOMPARE(lon, expected.longitude(GeoDataCoordinates::Degree));
QFUZZYCOMPARE(lat, expected.latitude(GeoDataCoordinates::Degree), 0.0001);
}
}
}
QTEST_MAIN(Marble::GnomonicProjectionTest)
#include "GnomonicProjectionTest.moc"
|