LocationIndexOfLine.h 2.52 KB
Newer Older
xuebingbing's avatar
xuebingbing committed
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 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74
/**********************************************************************
 *
 * GEOS - Geometry Engine Open Source
 * http://geos.osgeo.org
 *
 * Copyright (C) 2005-2006 Refractions Research Inc.
 * Copyright (C) 2001-2002 Vivid Solutions Inc.
 *
 * This is free software; you can redistribute and/or modify it under
 * the terms of the GNU Lesser General Public Licence as published
 * by the Free Software Foundation.
 * See the COPYING file for more information.
 *
 **********************************************************************
 *
 * Last port: linearref/LocationIndexOfLine.java r731
 *
 **********************************************************************/

#ifndef GEOS_LINEARREF_LOCATIONINDEXOFLINE_H
#define GEOS_LINEARREF_LOCATIONINDEXOFLINE_H

#include <geos/geom/Coordinate.h>
#include <geos/geom/Geometry.h>
#include <geos/linearref/LinearLocation.h>

namespace geos {
namespace linearref { // geos::linearref

/** \brief
 * Determines the location of a subline along a linear [Geometry](@ref geom::Geometry).
 *
 * The location is reported as a pair of {@link LinearLocation}s.
 *
 * @note Currently this algorithm is not guaranteed to
 *       return the correct substring in some situations where
 *       an endpoint of the test line occurs more than once in the input line.
 *       (However, the common case of a ring is always handled correctly).
 */
class LocationIndexOfLine {
    /**
     * MD - this algorithm has been extracted into a class
     * because it is intended to validate that the subline truly is a subline,
     * and also to use the internal vertex information to unambiguously locate the subline.
     */
private:
    const geom::Geometry* linearGeom;

public:

    /** \brief
     * Determines the location of a subline along a linear [Geometry](@ref geom::Geometry).
     *
     * The location is reported as a pair of [LinearLocations](@ref LinearLocation).
     *
     * @note Currently this algorithm is not guaranteed to
     *       return the correct substring in some situations where
     *       an endpoint of the test line occurs more than once in the input line.
     *       (However, the common case of a ring is always handled correctly).
     *
     * @note Caller must take of releasing with delete[]
     *
     */
    static LinearLocation* indicesOf(const geom::Geometry* linearGeom, const geom::Geometry* subLine);

    LocationIndexOfLine(const geom::Geometry* linearGeom);

    /// Caller must take of releasing with delete[]
    LinearLocation* indicesOf(const geom::Geometry* subLine) const;
};
}
}

#endif