File indexing completed on 2024-09-08 03:35:19
0001 // SPDX-License-Identifier: LGPL-2.1-or-later 0002 // 0003 // SPDX-FileCopyrightText: 2012 Thibaut Gridel <tgridel@free.fr> 0004 0005 0006 #include <QMetaType> 0007 #include "TileId.h" 0008 #include "GeoDataCoordinates.h" 0009 #include "TestUtils.h" 0010 0011 namespace Marble 0012 { 0013 0014 class TileIdTest : public QObject 0015 { 0016 Q_OBJECT 0017 0018 private Q_SLOTS: 0019 void testFromCoordinates_data(); 0020 void testFromCoordinates(); 0021 0022 }; 0023 0024 0025 void TileIdTest::testFromCoordinates_data() 0026 { 0027 QTest::addColumn<qreal>( "lon" ); 0028 QTest::addColumn<qreal>( "lat" ); 0029 QTest::addColumn<int>( "zoom" ); 0030 QTest::addColumn<int>( "x" ); 0031 QTest::addColumn<int>( "y" ); 0032 0033 for ( int zoom = 1; zoom < 19; ++zoom) { 0034 int last = (2 << (zoom-1)) -1; 0035 int quarter = qRound(last/4.0); 0036 int mid = qRound(last/2.0); 0037 int three = mid + quarter; 0038 0039 addRow() << qreal(-180.0) << qreal(0.0) << zoom << 0 << mid; 0040 addRow() << qreal(-90.0) << qreal(0.0) << zoom << quarter << mid; 0041 addRow() << qreal(0.0) << qreal(0.0) << zoom << mid << mid; 0042 addRow() << qreal(90.0) << qreal(0.0) << zoom << three << mid; 0043 addRow() << qreal(180.0) << qreal(0.0) << zoom << last << mid; 0044 0045 addRow() << qreal(-180.0) << qreal(-89.9999) << zoom << 0 << last; 0046 addRow() << qreal(-90.0) << qreal(-89.9999) << zoom << quarter << last; 0047 addRow() << qreal(0.0) << qreal(-89.9999) << zoom << mid << last; 0048 addRow() << qreal(90.0) << qreal(-89.9999) << zoom << three << last; 0049 addRow() << qreal(180.0) << qreal(-89.9999) << zoom << last << last; 0050 0051 addRow() << qreal(-180.0) << qreal(89.9999) << zoom << 0 << 0; 0052 addRow() << qreal(-90.0) << qreal(89.9999) << zoom << quarter << 0; 0053 addRow() << qreal(0.0) << qreal(89.9999) << zoom << mid << 0; 0054 addRow() << qreal(90.0) << qreal(89.9999) << zoom << three << 0; 0055 addRow() << qreal(180.0) << qreal(89.9999) << zoom << last << 0; 0056 0057 addRow() << qreal(-180.0) << qreal(-179.9999) << zoom << 0 << mid; 0058 addRow() << qreal(-90.0) << qreal(-179.9999) << zoom << quarter << mid; 0059 addRow() << qreal(0.0) << qreal(-179.9999) << zoom << mid << mid; 0060 addRow() << qreal(90.0) << qreal(-179.9999) << zoom << three << mid; 0061 addRow() << qreal(180.0) << qreal(-179.9999) << zoom << last << mid; 0062 0063 addRow() << qreal(-180.0) << qreal(179.9999) << zoom << 0 << mid-1; 0064 addRow() << qreal(-90.0) << qreal(179.9999) << zoom << quarter << mid-1; 0065 addRow() << qreal(0.0) << qreal(179.9999) << zoom << mid << mid-1; 0066 addRow() << qreal(90.0) << qreal(179.9999) << zoom << three << mid-1; 0067 addRow() << qreal(180.0) << qreal(179.9999) << zoom << last << mid-1; 0068 } 0069 } 0070 0071 void TileIdTest::testFromCoordinates() 0072 { 0073 QFETCH( qreal, lon ); 0074 QFETCH( qreal, lat ); 0075 QFETCH( int, zoom); 0076 QFETCH( int, x); 0077 QFETCH( int, y); 0078 0079 const TileId tile = TileId::fromCoordinates(GeoDataCoordinates( lon , lat, 0, GeoDataCoordinates::Degree), zoom ); 0080 0081 QCOMPARE( tile.x(), x ); 0082 QCOMPARE( tile.y(), y ); 0083 } 0084 0085 } 0086 0087 QTEST_MAIN( Marble::TileIdTest ) 0088 0089 #include "TileIdTest.moc"