QGIS/src/core/qgspoint.cpp
jef 1e4e5fab04 cleanups
- remove superfluous backslashes
- fix QgsDebugMsg macro
- disable code with #if 0/#endif instead of commenting it out
- remove namespaces from ogr converter plugin



git-svn-id: http://svn.osgeo.org/qgis/trunk@9218 c8812cc2-4d05-0410-92ff-de0c093fc19c
2008-08-30 14:53:45 +00:00

126 lines
3.1 KiB
C++

/***************************************************************************
qgspoint.cpp - description
-------------------
begin : Sat Jun 22 2002
copyright : (C) 2002 by Gary E.Sherman
email : sherman at mrcc.com
***************************************************************************/
/***************************************************************************
* *
* This program is free software; you can redistribute it and/or modify *
* it under the terms of the GNU General Public License as published by *
* the Free Software Foundation; either version 2 of the License, or *
* (at your option) any later version. *
* *
***************************************************************************/
/* $Id$ */
#include "qgspoint.h"
#include <cmath>
#include <QTextStream>
QgsPoint::QgsPoint( const QgsPoint& p )
{
m_x = p.x();
m_y = p.y();
}
QString QgsPoint::toString() const
{
QString rep;
QTextStream ot( &rep );
ot.setRealNumberPrecision( 12 );
ot << m_x << ", " << m_y;
return rep;
}
QString QgsPoint::toString( int thePrecision ) const
{
QString rep = QString::number( m_x, 'f', thePrecision ) + QString( "," ) +
QString::number( m_y, 'f', thePrecision );
return rep;
}
QString QgsPoint::wellKnownText() const
{
return QString( "POINT(%1 %2)" ).arg( QString::number( m_x, 'f', 18 ) ).arg( QString::number( m_y, 'f', 18 ) );
}
double QgsPoint::sqrDist( double x, double y ) const
{
return ( m_x -x )*( m_x - x ) + ( m_y - y )*( m_y - y );
}
double QgsPoint::sqrDist( const QgsPoint& other ) const
{
return sqrDist( other.x(), other.y() );
}
// operators
bool QgsPoint::operator==( const QgsPoint & other )
{
if (( m_x == other.x() ) && ( m_y == other.y() ) )
return true;
else
return false;
}
bool QgsPoint::operator!=( const QgsPoint & other ) const
{
if (( m_x == other.x() ) && ( m_y == other.y() ) )
return false;
else
return true;
}
QgsPoint & QgsPoint::operator=( const QgsPoint & other )
{
if ( &other != this )
{
m_x = other.x();
m_y = other.y();
}
return *this;
}
void QgsPoint::multiply( const double& scalar )
{
m_x *= scalar;
m_y *= scalar;
}
int QgsPoint::onSegment( const QgsPoint& a, const QgsPoint& b ) const
{
//algorithm from 'graphics GEMS', A. Paeth: 'A Fast 2D Point-on-line test'
if (
fabs(( b.y() - a.y() ) * ( m_x - a.x() ) - ( m_y - a.y() ) * ( b.x() - a.x() ) )
>= qMax( fabs( b.x() - a.x() ), fabs( b.y() - a.y() ) )
)
{
return 0;
}
if (( b.x() < a.x() && a.x() < m_x ) || ( b.y() < a.y() && a.y() < m_y ) )
{
return 1;
}
if (( m_x < a.x() && a.x() < b.x() ) || ( m_y < a.y() && a.y() < b.y() ) )
{
return 1;
}
if (( a.x() < b.x() && b.x() < m_x ) || ( a.y() < b.y() && b.y() < m_y ) )
{
return 3;
}
if (( m_x < b.x() && b.x() < a.x() ) || ( m_y < b.y() && b.y() < a.y() ) )
{
return 3;
}
return 2;
}