/** * \file src/snapped-point.cpp * \brief SnappedPoint class. * * Authors: * Mathieu Dimanche * Diederik van Lierop * * Released under GNU GPL, read the file 'COPYING' for more information. */ #include "snapped-point.h" // overloaded constructor Inkscape::SnappedPoint::SnappedPoint(Geom::Point const &p, SnapTargetType const &target, Geom::Coord const &d, Geom::Coord const &t, bool const &a) : _point(p), _target(target), _distance(d), _tolerance(t), _always_snap(a) { _at_intersection = false; _second_distance = NR_HUGE; _second_tolerance = 0; _second_always_snap = false; _transformation = Geom::Point(1,1); } Inkscape::SnappedPoint::SnappedPoint(Geom::Point const &p, SnapTargetType const &target, Geom::Coord const &d, Geom::Coord const &t, bool const &a, bool const &at_intersection, Geom::Coord const &d2, Geom::Coord const &t2, bool const &a2) : _point(p), _target(target), _at_intersection(at_intersection), _distance(d), _tolerance(t), _always_snap(a), _second_distance(d2), _second_tolerance(t2), _second_always_snap(a2) { _transformation = Geom::Point(1,1); } Inkscape::SnappedPoint::SnappedPoint() { _point = Geom::Point(0,0); _target = SNAPTARGET_UNDEFINED, _distance = NR_HUGE; _tolerance = 0; _always_snap = false; _at_intersection = false; _second_distance = NR_HUGE; _second_tolerance = 0; _second_always_snap = false; _transformation = Geom::Point(1,1); } Inkscape::SnappedPoint::~SnappedPoint() { } Geom::Coord Inkscape::SnappedPoint::getDistance() const { return _distance; } Geom::Coord Inkscape::SnappedPoint::getTolerance() const { return _tolerance; } bool Inkscape::SnappedPoint::getAlwaysSnap() const { return _always_snap; } Geom::Coord Inkscape::SnappedPoint::getSecondDistance() const { return _second_distance; } Geom::Coord Inkscape::SnappedPoint::getSecondTolerance() const { return _second_tolerance; } bool Inkscape::SnappedPoint::getSecondAlwaysSnap() const { return _second_always_snap; } void Inkscape::SnappedPoint::getPoint(Geom::Point &p) const { // When we have snapped if (getSnapped()) { // then return the snapped point by overwriting p p = _point; } //otherwise p will be left untouched; this way the caller doesn't have to check wether we've snapped } // search for the closest snapped point bool getClosestSP(std::list &list, Inkscape::SnappedPoint &result) { bool success = false; for (std::list::const_iterator i = list.begin(); i != list.end(); i++) { if ((i == list.begin()) || (*i).getDistance() < result.getDistance()) { result = *i; success = true; } } return success; } /* Local Variables: mode:c++ c-file-style:"stroustrup" c-file-offsets:((innamespace . 0)(inline-open . 0)(case-label . +)) indent-tabs-mode:nil fill-column:99 End: */ // vim: filetype=cpp:expandtab:shiftwidth=4:tabstop=8:softtabstop=4 :