/home/andreas/src/svn/mapnik/include/mapnik/projection.hpp

Go to the documentation of this file.
00001 /*****************************************************************************
00002  * 
00003  * This file is part of Mapnik (c++ mapping toolkit)
00004  *
00005  * Copyright (C) 2006 Artem Pavlenko
00006  *
00007  * This library is free software; you can redistribute it and/or
00008  * modify it under the terms of the GNU Lesser General Public
00009  * License as published by the Free Software Foundation; either
00010  * version 2.1 of the License, or (at your option) any later version.
00011  *
00012  * This library is distributed in the hope that it will be useful,
00013  * but WITHOUT ANY WARRANTY; without even the implied warranty of
00014  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
00015  * Lesser General Public License for more details.
00016  *
00017  * You should have received a copy of the GNU Lesser General Public
00018  * License along with this library; if not, write to the Free Software
00019  * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
00020  *
00021  *****************************************************************************/
00022 
00023 //$Id$
00024 
00025 #ifndef PROJECTION_HPP
00026 #define PROJECTION_HPP
00027 
00028 // stl
00029 #include <string>
00030 #include <iostream>
00031 #include <stdexcept>
00032 // boost
00033 #include <boost/utility.hpp>
00034 // mapnik
00035 #include <mapnik/envelope.hpp>
00036 
00037 namespace mapnik {
00038     
00039     class proj_init_error : public std::runtime_error
00040     {
00041     public:
00042         proj_init_error(std::string const& params)
00043             : std::runtime_error("failed to initialize projection with:" + params) {}
00044     };
00045     
00046     class MAPNIK_DECL projection
00047     {
00048         friend class proj_transform;
00049     public:
00050         explicit projection(std::string params = "+proj=latlong +ellps=WGS84");
00051         projection(projection const& rhs);
00052         ~projection();
00053         
00054         projection& operator=(projection const& rhs);
00055         bool is_initialized() const;
00056         bool is_geographic() const;
00057         std::string const& params() const;
00058       
00059         void forward(double & x, double &y ) const;
00060         void inverse(double & x,double & y) const;
00061         
00062     private:
00063         void init(); 
00064         void swap (projection& rhs);
00065        
00066     private:
00067         std::string params_;
00068         void * proj_;
00069     };
00070 }
00071 
00072 #endif //PROJECTION_HPP

Generated on Thu Jul 19 17:59:27 2007 for Mapnik by  doxygen 1.4.7