File indexing completed on 2024-09-15 03:35:06

0001 #include "SimpleMapImage.h"
0002 
0003 #include "InterpolationMethod.h"
0004 
0005 #include <cmath>
0006 
0007 SimpleMapImage::SimpleMapImage( QString const & fileName )
0008     : m_image( fileName ),
0009       m_mapWidthPixel( m_image.width() ),
0010       m_mapHeightPixel( m_image.height() )
0011 {
0012     if ( m_image.isNull() )
0013         qFatal( "Invalid image '%s'", fileName.toStdString().c_str() );
0014 }
0015 
0016 QRgb SimpleMapImage::pixel( double const lonRad,  double const latRad )
0017 {
0018     double const x = lonRadToPixelX( lonRad );
0019     double const y = latRadToPixelY( latRad );
0020     return m_interpolationMethod->interpolate( x, y );
0021 }
0022 
0023 QRgb SimpleMapImage::pixel( int const x, int const y )
0024 {
0025     return m_image.pixel( x, m_mapHeightPixel - y - 1 );
0026 }
0027 
0028 void SimpleMapImage::setInterpolationMethod( InterpolationMethod * const interpolationMethod )
0029 {
0030     m_interpolationMethod = interpolationMethod;
0031     m_interpolationMethod->setMapImage( this );
0032 }
0033 
0034 inline double SimpleMapImage::lonRadToPixelX( double const lonRad ) const
0035 {
0036     return static_cast<double>( m_mapWidthPixel ) / ( 2.0 * M_PI ) * lonRad
0037             + 0.5 * static_cast<double>( m_mapWidthPixel );
0038 }
0039 
0040 inline double SimpleMapImage::latRadToPixelY( double const latRad ) const
0041 {
0042     return static_cast<double>( m_mapHeightPixel ) / M_PI * latRad
0043             + 0.5 * static_cast<double>( m_mapHeightPixel );
0044 }