00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025 #include "anchor.hpp"
00026
00027
00028 bool Anchor::isHanging( const Anchor &rOther ) const
00029 {
00030 if( m_priority <= rOther.m_priority )
00031 return false;
00032
00033
00034
00035 int deltaX = getXPosAbs() - rOther.getXPosAbs();
00036 int deltaY = getYPosAbs() - rOther.getYPosAbs();
00037
00038
00039 return (isPoint() && rOther.m_rCurve.getMinDist( deltaX, deltaY ) == 0) ||
00040 (rOther.isPoint() && m_rCurve.getMinDist( -deltaX, -deltaY ) == 0);
00041 }
00042
00043
00044 bool Anchor::canHang( const Anchor &rOther, int &xOffset, int &yOffset ) const
00045 {
00046 int deltaX = getXPosAbs() - (rOther.getXPosAbs() + xOffset);
00047 int deltaY = getYPosAbs() - (rOther.getYPosAbs() + yOffset);
00048
00049
00050 if( (isPoint() && rOther.m_rCurve.getMinDist( deltaX, deltaY ) < m_range) )
00051 {
00052
00053 int xx, yy;
00054 float p = rOther.m_rCurve.getNearestPercent( deltaX, deltaY );
00055 rOther.m_rCurve.getPoint( p, xx, yy );
00056
00057 xOffset = getXPosAbs() - (rOther.getXPosAbs() + xx);
00058 yOffset = getYPosAbs() - (rOther.getYPosAbs() + yy);
00059 return true;
00060 }
00061 else if( (rOther.isPoint() &&
00062 m_rCurve.getMinDist( -deltaX, -deltaY ) < m_range) )
00063 {
00064
00065 int xx, yy;
00066 float p = m_rCurve.getNearestPercent( -deltaX, -deltaY );
00067 m_rCurve.getPoint( p, xx, yy );
00068
00069 xOffset = (getXPosAbs() + xx) - rOther.getXPosAbs();
00070 yOffset = (getYPosAbs() + yy) - rOther.getYPosAbs();
00071 return true;
00072 }
00073 else
00074 {
00075 return false;
00076 }
00077 }