summaryrefslogtreecommitdiff
path: root/test/text/calculate_tile_distances.test.cpp
blob: 990de3d4ecbc4d6a45b94f30a46a539f9f9f35ea (plain)
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
#include <mbgl/test/util.hpp>

#include <mbgl/geometry/anchor.hpp>
#include <mbgl/layout/symbol_layout.hpp>
#include <mbgl/tile/geometry_tile_data.hpp>

using namespace mbgl;

TEST(calculateTileDistances, Point) {
    const GeometryCoordinates line = {Point<int16_t>{1, 1}};
    const auto distances = SymbolLayout::calculateTileDistances(line, Anchor(1.0f, 1.0f, .0f, 0u));
    EXPECT_EQ(distances.size(), 1u);
    EXPECT_EQ(distances[0], .0f);
}

TEST(calculateTileDistances, Line) {
    const GeometryCoordinates line = {
        Point<int16_t>{1, 1}, Point<int16_t>{1, 2}, Point<int16_t>{1, 3}, Point<int16_t>{1, 4}};
    const auto distances = SymbolLayout::calculateTileDistances(line, Anchor(1.0f, 3.0f, .0f, 2u));
    EXPECT_EQ(distances, std::vector<float>({2.0f, 1.0f, 0.0f, 1.0f}));
}

TEST(calculateTileDistances, EmptySegment) {
    const GeometryCoordinates line = {};
    const auto distances = SymbolLayout::calculateTileDistances(line, Anchor(1.0f, 1.0f, .0f));
    EXPECT_EQ(distances.size(), 0u);
}