⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 proj4_base.cpp

📁 这是一个GPS相关的程序
💻 CPP
📖 第 1 页 / 共 2 页
字号:

///////////////////////////////////////////////////////////
//                                                       //
//                         SAGA                          //
//                                                       //
//      System for Automated Geoscientific Analyses      //
//                                                       //
//                    Module Library:                    //
//                   Projection_Proj4                    //
//                                                       //
//-------------------------------------------------------//
//                                                       //
//                    PROJ4_Base.cpp                     //
//                                                       //
//                 Copyright (C) 2003 by                 //
//                      Olaf Conrad                      //
//                                                       //
//-------------------------------------------------------//
//                                                       //
// This file is part of 'SAGA - System for Automated     //
// Geoscientific Analyses'. SAGA 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; version 2 of the License.   //
//                                                       //
// SAGA is distributed in the hope that it will be       //
// useful, but WITHOUT ANY WARRANTY; without even the    //
// implied warranty of MERCHANTABILITY or FITNESS FOR A  //
// PARTICULAR PURPOSE. See the GNU General Public        //
// License for more details.                             //
//                                                       //
// You should have received a copy of the GNU General    //
// Public License along with this program; if not,       //
// write to the Free Software Foundation, Inc.,          //
// 59 Temple Place - Suite 330, Boston, MA 02111-1307,   //
// USA.                                                  //
//                                                       //
//-------------------------------------------------------//
//                                                       //
//    e-mail:     oconrad@saga-gis.org                   //
//                                                       //
//    contact:    Olaf Conrad                            //
//                Institute of Geography                 //
//                University of Goettingen               //
//                Goldschmidtstr. 5                      //
//                37077 Goettingen                       //
//                Germany                                //
//                                                       //
///////////////////////////////////////////////////////////

//---------------------------------------------------------


///////////////////////////////////////////////////////////
//														 //
//														 //
//														 //
///////////////////////////////////////////////////////////

//---------------------------------------------------------
#include "PROJ4_Base.h"

#include <string.h>


///////////////////////////////////////////////////////////
//														 //
//														 //
//														 //
///////////////////////////////////////////////////////////

//---------------------------------------------------------
CPROJ4_Base::CPROJ4_Base(void)
{
	Parameters.Add_Node(NULL, "SOURCE_NODE"	, _TL("Source Parameters")	, _TL(""));
	Parameters.Add_Node(NULL, "TARGET_NODE"	, _TL("Target Parameters")	, _TL(""));

	Parameters.Add_Node(NULL, "PROJECTION"	, _TL("Projection")			, _TL(""));

	//-----------------------------------------------------
	bInitialized	= false;

	Initialize();
}


//---------------------------------------------------------
CPROJ4_Base::~CPROJ4_Base(void)
{}


///////////////////////////////////////////////////////////
//														 //
//					Initialization						 //
//														 //
///////////////////////////////////////////////////////////

//---------------------------------------------------------
#define BESSEL_A	6377397.16
#define BESSEL_B	6356078.76

//---------------------------------------------------------
bool CPROJ4_Base::Initialize(void)
{
	char				c;
	int					i;
	struct PJ_LIST		*pProjections;
	struct PJ_ELLPS		*pEllipses;
//	struct PJ_DATUMS	*pDatums;
	struct PJ_UNITS		*pUnits;
	CSG_String			sList, sName, sDesc;
	CSG_Parameter			*pNode_0, *pNode_1, *pNode_2, *pNode_3;

	//-----------------------------------------------------
	if( !bInitialized )
	{
		bInitialized	= true;

		pNode_0	= Parameters("PROJECTION");

		pNode_1	= Parameters.Add_Choice(
			pNode_0, "DIRECTION"	, _TL("Direction"),
			_TL(""),

			CSG_String::Format(SG_T("%s|%s|"),
				_TL("Geodetic to Projection"),
				_TL("Projection to Geodetic")
			), 0
		);


		//-------------------------------------------------
		// Projections List...

		sDesc	= _TL("Available Projections:");

		for(pProjections=pj_list; pProjections->id; ++pProjections)
		{
			sName.Clear();

			for(i=0; i<256; i++)
			{
				c	= (*pProjections->descr)[i];

				if( c != '\0' && c != '\n' )
				{
					sName	+= c;
				}
				else
				{
					break;
				}
			}

			sList	+= CSG_String::Format(SG_T("%s|"), sName.c_str());
			sDesc	+= CSG_String::Format(SG_T("\n[%s] %s"), pProjections->id, *pProjections->descr);

			Initialize_ExtraParms(pProjections, sName);
		}

		if( sList.Length() > 0 )
		{
			pNode_1	= Parameters.Add_Choice(
				pNode_0, "PROJ_TYPE"	, _TL("Projection Type"),
				sDesc,
				sList
			);
		}


		//-------------------------------------------------
		// Ellipsoid...

		pNode_1	= Parameters.Add_Choice(
			pNode_0, "ELLIPSOID"	, _TL("Ellipsoid"),
			_TL(""),

			CSG_String::Format(SG_T("%s|%s|%s|%s|%s|%s|"),
				_TL("Predefined Standard Ellipsoids"),
				_TL("Semimajor Axis and Semiminor Axis"),
				_TL("Semimajor Axis and Flattening"),
				_TL("Semimajor Axis and Reciprocal Flattening"),
				_TL("Semimajor Axis and Eccentricity"),
				_TL("Semimajor Axis and Eccentricity Squared|")
			)
		);

		sList.Clear();

		for(pEllipses=pj_ellps; pEllipses->id; ++pEllipses)
		{
			sList	+= CSG_String::Format(SG_T("%s (%s, %s)|"), pEllipses->name, pEllipses->major, pEllipses->ell);
		}

		if( sList.Length() > 0 )
		{
			pNode_2	= Parameters.Add_Choice(
				pNode_1, "ELLPS_PREDEF"	, _TL("Predefined Standard Ellipsoids"),
				_TL(""),
				sList
			);
		}

		pNode_2	= Parameters.Add_Value(
			pNode_1, "ELLPS_A"		, _TL("Semimajor Axis (a)"),
			_TL("Semimajor axis or equatorial radius."),
			PARAMETER_TYPE_Double	, BESSEL_A
		);

		pNode_3	= Parameters.Add_Value(
			pNode_2, "ELLPS_B"		, _TL("Semiminor Axis (b)"),
			_TL("Semiminor axis or polar radius."),
			PARAMETER_TYPE_Double	, BESSEL_B
		);

		pNode_3	= Parameters.Add_Value(
			pNode_2, "ELLPS_F"		, _TL("Flattening (f)"),
			_TL(""),
			PARAMETER_TYPE_Double	, (BESSEL_A - BESSEL_B) / BESSEL_A
		);

		pNode_3	= Parameters.Add_Value(
			pNode_2, "ELLPS_RF"		, _TL("Reciprocal Flattening (rf)"),
			_TL(""),
			PARAMETER_TYPE_Double	, BESSEL_A / (BESSEL_A - BESSEL_B)
		);

		pNode_3	= Parameters.Add_Value(
			pNode_2, "ELLPS_E"		, _TL("Eccentricity (e)"),
			_TL(""),
			PARAMETER_TYPE_Double	, sqrt(BESSEL_A*BESSEL_A + BESSEL_B*BESSEL_B)
		);

		pNode_3	= Parameters.Add_Value(
			pNode_2, "ELLPS_ES"		, _TL("Squared Eccentricity (es)"),
			_TL(""),
			PARAMETER_TYPE_Double	, BESSEL_A*BESSEL_A + BESSEL_B*BESSEL_B
		);


		/*/-------------------------------------------------
		// Datums...

		sList.Clear();

		for(pDatums=pj_datums; pDatums->id; ++pDatums)
		{
			sList	+= CSG_String::Format(sName, SG_T("%s (%s) "), pDatums->defn, pDatums->ellipse_id);

			if( pDatums->comments != NULL && strlen(pDatums->comments) > 0 )
			{
				sList	+= CSG_String::Format(SG_T(%s"), pDatums->comments);
			}

			sList	+= '|';
		}

		if( sList.Length > 0 )
		{
			pNode_1	= Parameters.Add_Choice(
				pNode_0, "DATUM"		, "Datum",
				_TL(""),
				sList
			);
		}/**/


		//-------------------------------------------------
		// Units...

		sList.Clear();

		for(pUnits=pj_units; pUnits->id; ++pUnits)
		{
			sList	+= CSG_String::Format(SG_T("%s (%s)|"), pUnits->name, pUnits->to_meter);
		}

		if( sList.Length() > 0 )
		{
			pNode_1	= Parameters.Add_Choice(
				pNode_0, "UNIT"			, _TL("Unit"),
				_TL(""),
				sList, 1
			);
		}


		//-------------------------------------------------
		// More Settings...

		pNode_1	= Parameters.Add_Value(
			pNode_0, "LON_0"			, _TL("Central Meridian"),
			_TL(""),
			PARAMETER_TYPE_Double, 0.0
		);

		pNode_1	= Parameters.Add_Value(
			pNode_0, "LAT_0"			, _TL("Central Parallel"),
			_TL(""),
			PARAMETER_TYPE_Double, 0.0
		);

		pNode_1	= Parameters.Add_Value(
			pNode_0, "X_0"				, _TL("False Easting"),
			_TL(""),
			PARAMETER_TYPE_Double, 0.0
		);

		pNode_1	= Parameters.Add_Value(
			pNode_0, "Y_0"				, _TL("False Northing"),
			_TL(""),
			PARAMETER_TYPE_Double, 0.0
		);
	}

	return( bInitialized );
}

//---------------------------------------------------------
#define ISID(sID)					!strcmp(pProjection->id, sID)

#define ADD_BOOLE(key, name, val)	pParms->Add_Value(NULL, key, name, _TL(""), PARAMETER_TYPE_Bool	, val);
#define ADD_INTEG(key, name, val)	pParms->Add_Value(NULL, key, name, _TL(""), PARAMETER_TYPE_Int	, val);
#define ADD_FLOAT(key, name, val)	pParms->Add_Value(NULL, key, name, _TL(""), PARAMETER_TYPE_Double, val);

//---------------------------------------------------------
bool CPROJ4_Base::Initialize_ExtraParms(struct PJ_LIST *pProjection, const SG_Char *sName)
{
	CSG_Parameters	*pParms;

	pParms	= Add_Parameters(CSG_String(pProjection->id), sName, CSG_String(*pProjection->descr));


	//-----------------------------------------------------
	// Cylindrical Projections...

	if(	ISID("cea"		)	// Equal Area Cylindrical
	||	ISID("eqc"		)	// Equidistant Cylindrical (Plate Caree) 
	||	ISID("merc"		) )	// Mercator 
	{
		ADD_FLOAT(SG_T("lat_ts")	, _TL("True Scale Latitude")	, 0.0);
	}

	if(	ISID("utm"		) )	// Universal Transverse Mercator (UTM)
	{
		ADD_INTEG(SG_T("zone")	, _TL("Zone")				, 32);
		ADD_BOOLE(SG_T("south")	, _TL("South")				, false);
	}

	if(	ISID("omerc"	) )	// Oblique Mercator 
	{
		ADD_FLOAT(SG_T("lat_1")	, _TL("Latitude 1")			, 40.0);
		ADD_FLOAT(SG_T("lon_1")	, _TL("Longitude 1"	)		,-20.0);
		ADD_FLOAT(SG_T("lat_2")	, _TL("Latitude 2")			, 50.0);
		ADD_FLOAT(SG_T("lon_2")	, _TL("Longitude 2"	)		, 20.0);
	}

	//-----------------------------------------------------
	// Pseudocylindrical Projections...

	if(	ISID("gn_sinu"	) )	// General Sinusoidal Series
	{
		ADD_FLOAT(SG_T("m")		, SG_T("m")					, 0.5);
		ADD_FLOAT(SG_T("n")		, SG_T("n")					, 1.0 + M_PI_045);
	}

	if(	ISID("loxim"	) )	// Loximuthal
	{
		ADD_FLOAT(SG_T("lat_1")	, _TL("Latitude 1")			, 40.0);
	}

	if(	ISID("urmfps"	) )	// Urmaev Flat-Polar Sinusoidal
	{
		ADD_FLOAT(SG_T("n")		, SG_T("n")					, 1.0);
	}

	if(	ISID("urm5"		) )	// Urmaev V
	{
		ADD_FLOAT(SG_T("n")		, SG_T("n")					, 1.0);
		ADD_FLOAT(SG_T("q")		, SG_T("q")					, 1.0);
		ADD_FLOAT(SG_T("alphi")	, SG_T("alphi")				, 45.0);
	}

	if(	ISID("wink1"	)	// Winkel I
	||	ISID("wag3"		) )	// Wagner III
	{
		ADD_FLOAT(SG_T("lat_ts"), _TL("True Scale Latitude"), 45.0);
	}

	if(	ISID("wink2"	) )	// Winkel II
	{
		ADD_FLOAT(SG_T("lat_1")	, _TL("Latitude 1")			, 40.0);
	}


	//-----------------------------------------------------
	// Conic Projections...

	if(	ISID("aea"		)	// Albers Equal Area
	||	ISID("eqdc"		)	// Equidistant Conic
	||	ISID("euler"	)	// Euler 
	||	ISID("imw_p"	)	// International Map of the World Polyconic 
	||	ISID("murd1"	)	// Murdoch I 
	||	ISID("murd2"	)	// Murdoch II 
	||	ISID("murd3"	)	// Murdoch III 
	||	ISID("pconic"	)	// Perspective Conic 
	||	ISID("tissot"	)	// Tissot 
	||	ISID("vitk1"	) )	// Vitkovsky I 
	{
		ADD_FLOAT(SG_T("lat_1")	, _TL("Latitude 1")			, 33.0);
		ADD_FLOAT(SG_T("lat_2")	, _TL("Latitude 2")			, 45.0);
	}

	if(	ISID("lcc"		) )	// Lambert Conformal Conic 

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -