Skip to content

File ForceOrderPoints.cpp

File List > detail > transform > ForceOrderPoints.cpp

Go to the documentation of this file

// Copyright (c) 2012-2013, IGN France.
// Copyright (c) 2012-2022, Oslandia.
// SPDX-License-Identifier: LGPL-2.0-or-later

#include "SFCGAL/detail/transform/ForceOrderPoints.h"
#include "SFCGAL/Point.h"
#include "SFCGAL/Polygon.h"
#include "SFCGAL/Triangle.h"
#include "SFCGAL/algorithm/orientation.h"

namespace SFCGAL::transform {

ForceOrderPoints::ForceOrderPoints(bool orientCCW) : _orientCCW(orientCCW) {}

void
ForceOrderPoints::transform(Point & /*p*/)
{
}

void
ForceOrderPoints::visit(Triangle &t)
{
  if (!algorithm::isCounterClockWiseOriented(t)) {
    // not pointing up, reverse
    if (_orientCCW) {
      t.reverse();
    }
  } else {
    if (!_orientCCW) {
      t.reverse();
    }
  }

  Transform::visit(t);
}

void
ForceOrderPoints::visit(Polygon &p)
{
  LineString &ext = p.exteriorRing();

  if (!algorithm::isCounterClockWiseOriented(p.exteriorRing())) {
    // exterior ring not pointing up, reverse
    if (_orientCCW) {
      ext.reverse();
    }
  } else {
    if (!_orientCCW) {
      ext.reverse();
    }
  }
  const bool isCCWO{algorithm::isCounterClockWiseOriented(ext)};
  for (size_t i = 0; i < p.numInteriorRings(); ++i) {
    LineString &inter = p.interiorRingN(i);

    if (algorithm::isCounterClockWiseOriented(inter) == isCCWO) {
      inter.reverse();
    }
  }

  Transform::visit(p);
}

} // namespace SFCGAL::transform