File: interior.cpp

package info (click to toggle)
mapnik 3.1.0%2Bds-1
  • links: PTS, VCS
  • area: main
  • in suites: bullseye
  • size: 19,548 kB
  • sloc: cpp: 144,430; python: 30,187; sh: 797; makefile: 172; xml: 140; lisp: 13
file content (31 lines) | stat: -rw-r--r-- 742 bytes parent folder | download | duplicates (3)
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
#include "catch.hpp"

#include <mapnik/geometry/interior.hpp>

TEST_CASE("polygon interior") {

SECTION("empty polygon") {

    mapnik::geometry::polygon<double> poly;
    mapnik::geometry::point<double> pt;

    CHECK(!mapnik::geometry::interior(poly, 1.0, pt));
}

SECTION("interior of a square") {

    mapnik::geometry::polygon<double> poly;
    poly.exterior_ring.emplace_back(-1, -1);
    poly.exterior_ring.emplace_back( 1, -1);
    poly.exterior_ring.emplace_back( 1,  1);
    poly.exterior_ring.emplace_back(-1,  1);
    poly.exterior_ring.emplace_back(-1, -1);

    mapnik::geometry::point<double> pt{ -3, -3 };

    CHECK(mapnik::geometry::interior(poly, 1.0, pt));
    CHECK(pt.x == Approx(0));
    CHECK(pt.y == Approx(0));
}

}