📄 ogr_srs_proj4.cpp
字号:
else if( EQUAL(pszProjection,SRS_PT_ROBINSON) ) { sprintf( szProj4+strlen(szProj4), "+proj=robin +lon_0=%.16g +x_0=%.16g +y_0=%.16g ", GetNormProjParm(SRS_PP_CENTRAL_MERIDIAN,0.0), GetNormProjParm(SRS_PP_FALSE_EASTING,0.0), GetNormProjParm(SRS_PP_FALSE_NORTHING,0.0) ); } else if( EQUAL(pszProjection,SRS_PT_VANDERGRINTEN) ) { sprintf( szProj4+strlen(szProj4), "+proj=vandg +lon_0=%.16g +x_0=%.16g +y_0=%.16g +R_A ", GetNormProjParm(SRS_PP_CENTRAL_MERIDIAN,0.0), GetNormProjParm(SRS_PP_FALSE_EASTING,0.0), GetNormProjParm(SRS_PP_FALSE_NORTHING,0.0) ); } else if( EQUAL(pszProjection,SRS_PT_SINUSOIDAL) ) { sprintf( szProj4+strlen(szProj4), "+proj=sinu +lon_0=%.16g +x_0=%.16g +y_0=%.16g ", GetNormProjParm(SRS_PP_LONGITUDE_OF_CENTER,0.0), GetNormProjParm(SRS_PP_FALSE_EASTING,0.0), GetNormProjParm(SRS_PP_FALSE_NORTHING,0.0) ); } else if( EQUAL(pszProjection,SRS_PT_GALL_STEREOGRAPHIC) ) { sprintf( szProj4+strlen(szProj4), "+proj=gall +lon_0=%.16g +x_0=%.16g +y_0=%.16g ", GetNormProjParm(SRS_PP_CENTRAL_MERIDIAN,0.0), GetNormProjParm(SRS_PP_FALSE_EASTING,0.0), GetNormProjParm(SRS_PP_FALSE_NORTHING,0.0) ); } else if( EQUAL(pszProjection,SRS_PT_LAMBERT_CONFORMAL_CONIC_2SP) || EQUAL(pszProjection,SRS_PT_LAMBERT_CONFORMAL_CONIC_2SP_BELGIUM) ) { sprintf( szProj4+strlen(szProj4), "+proj=lcc +lat_1=%.16g +lat_2=%.16g +lat_0=%.16g +lon_0=%.16g" " +x_0=%.16g +y_0=%.16g ", GetNormProjParm(SRS_PP_STANDARD_PARALLEL_1,0.0), GetNormProjParm(SRS_PP_STANDARD_PARALLEL_2,0.0), GetNormProjParm(SRS_PP_LATITUDE_OF_ORIGIN,0.0), GetNormProjParm(SRS_PP_CENTRAL_MERIDIAN,0.0), GetNormProjParm(SRS_PP_FALSE_EASTING,0.0), GetNormProjParm(SRS_PP_FALSE_NORTHING,0.0) ); } else if( EQUAL(pszProjection,SRS_PT_LAMBERT_CONFORMAL_CONIC_1SP) ) { sprintf( szProj4+strlen(szProj4), "+proj=lcc +lat_1=%.16g +lat_0=%.16g +lon_0=%.16g" " +k_0=%.16g +x_0=%.16g +y_0=%.16g ", GetNormProjParm(SRS_PP_LATITUDE_OF_ORIGIN,0.0), GetNormProjParm(SRS_PP_LATITUDE_OF_ORIGIN,0.0), GetNormProjParm(SRS_PP_CENTRAL_MERIDIAN,0.0), GetNormProjParm(SRS_PP_SCALE_FACTOR,1.0), GetNormProjParm(SRS_PP_FALSE_EASTING,0.0), GetNormProjParm(SRS_PP_FALSE_NORTHING,0.0) ); } else if( EQUAL(pszProjection,SRS_PT_HOTINE_OBLIQUE_MERCATOR) ) { /* not clear how ProjParm[3] - angle from rectified to skewed grid - should be applied ... see the +not_rot flag for PROJ.4. Just ignoring for now. */ sprintf( szProj4+strlen(szProj4), "+proj=omerc +lat_0=%.16g +lonc=%.16g +alpha=%.16g" " +k=%.16g +x_0=%.16g +y_0=%.16g ", GetNormProjParm(SRS_PP_LATITUDE_OF_ORIGIN,0.0), GetNormProjParm(SRS_PP_CENTRAL_MERIDIAN,0.0), GetNormProjParm(SRS_PP_AZIMUTH,0.0), GetNormProjParm(SRS_PP_SCALE_FACTOR,1.0), GetNormProjParm(SRS_PP_FALSE_EASTING,0.0), GetNormProjParm(SRS_PP_FALSE_NORTHING,0.0) ); } else if( EQUAL(pszProjection,SRS_PT_KROVAK) ) { sprintf( szProj4+strlen(szProj4), "+proj=krovak +lat_0=%.16g +lon_0=%.16g +alpha=%.16g" " +k=%.16g +x_0=%.16g +y_0=%.16g ", GetNormProjParm(SRS_PP_LATITUDE_OF_CENTER,0.0), GetNormProjParm(SRS_PP_LONGITUDE_OF_CENTER,0.0), GetNormProjParm(SRS_PP_AZIMUTH,0.0), GetNormProjParm(SRS_PP_SCALE_FACTOR,1.0), GetNormProjParm(SRS_PP_FALSE_EASTING,0.0), GetNormProjParm(SRS_PP_FALSE_NORTHING,0.0) ); } else if( EQUAL(pszProjection,SRS_PT_SWISS_OBLIQUE_CYLINDRICAL) ) { sprintf( szProj4+strlen(szProj4), "+proj=omerc +lat_0=%.16g +lonc=%.16g" " +x_0=%.16g +y_0=%.16g ", GetNormProjParm(SRS_PP_LATITUDE_OF_ORIGIN,0.0), GetNormProjParm(SRS_PP_CENTRAL_MERIDIAN,0.0), GetNormProjParm(SRS_PP_FALSE_EASTING,0.0), GetNormProjParm(SRS_PP_FALSE_NORTHING,0.0) ); }/* -------------------------------------------------------------------- *//* Handle earth model. For now we just always emit the user *//* defined ellipsoid parameters. *//* -------------------------------------------------------------------- */ double dfSemiMajor = GetSemiMajor(); double dfInvFlattening = GetInvFlattening(); const char *pszPROJ4Ellipse = NULL; const char *pszDatum = GetAttrValue("DATUM"); if( ABS(dfSemiMajor-6378249.145) < 0.01 && ABS(dfInvFlattening-293.465) < 0.0001 ) { pszPROJ4Ellipse = "clrk80"; /* Clark 1880 */ } else if( ABS(dfSemiMajor-6378245.0) < 0.01 && ABS(dfInvFlattening-298.3) < 0.0001 ) { pszPROJ4Ellipse = "krass"; /* Krassovsky */ } else if( ABS(dfSemiMajor-6378388.0) < 0.01 && ABS(dfInvFlattening-297.0) < 0.0001 ) { pszPROJ4Ellipse = "intl"; /* International 1924 */ } else if( ABS(dfSemiMajor-6378160.0) < 0.01 && ABS(dfInvFlattening-298.25) < 0.0001 ) { pszPROJ4Ellipse = "aust_SA"; /* Australian */ } else if( ABS(dfSemiMajor-6377397.155) < 0.01 && ABS(dfInvFlattening-299.1528128) < 0.0001 ) { pszPROJ4Ellipse = "bessel"; /* Bessel 1841 */ } else if( ABS(dfSemiMajor-6377483.865) < 0.01 && ABS(dfInvFlattening-299.1528128) < 0.0001 ) { pszPROJ4Ellipse = "bess_nam"; /* Bessel 1841 (Namibia / Schwarzeck)*/ } else if( ABS(dfSemiMajor-6378160.0) < 0.01 && ABS(dfInvFlattening-298.247167427) < 0.0001 ) { pszPROJ4Ellipse = "GRS67"; /* GRS 1967 */ } else if( ABS(dfSemiMajor-6378137) < 0.01 && ABS(dfInvFlattening-298.257222101) < 0.000001 ) { pszPROJ4Ellipse = "GRS80"; /* GRS 1980 */ } else if( ABS(dfSemiMajor-6378206.4) < 0.01 && ABS(dfInvFlattening-294.9786982) < 0.0001 ) { pszPROJ4Ellipse = "clrk66"; /* Clarke 1866 */ } else if( ABS(dfSemiMajor-6378206.4) < 0.01 && ABS(dfInvFlattening-294.9786982) < 0.0001 ) { pszPROJ4Ellipse = "mod_airy"; /* Modified Airy */ } else if( ABS(dfSemiMajor-6377563.396) < 0.01 && ABS(dfInvFlattening-299.3249646) < 0.0001 ) { pszPROJ4Ellipse = "airy"; /* Modified Airy */ } else if( ABS(dfSemiMajor-6378200) < 0.01 && ABS(dfInvFlattening-298.3) < 0.0001 ) { pszPROJ4Ellipse = "helmert"; /* Helmert 1906 */ } else if( ABS(dfSemiMajor-6378155) < 0.01 && ABS(dfInvFlattening-298.3) < 0.0001 ) { pszPROJ4Ellipse = "fschr60m"; /* Modified Fischer 1960 */ } else if( ABS(dfSemiMajor-6377298.556) < 0.01 && ABS(dfInvFlattening-300.8017) < 0.0001 ) { pszPROJ4Ellipse = "evrstSS"; /* Everest (Sabah & Sarawak) */ } else if( ABS(dfSemiMajor-6378165.0) < 0.01 && ABS(dfInvFlattening-298.3) < 0.0001 ) { pszPROJ4Ellipse = "WGS60"; } else if( ABS(dfSemiMajor-6378145.0) < 0.01 && ABS(dfInvFlattening-298.25) < 0.0001 ) { pszPROJ4Ellipse = "WGS66"; } else if( ABS(dfSemiMajor-6378135.0) < 0.01 && ABS(dfInvFlattening-298.26) < 0.0001 ) { pszPROJ4Ellipse = "WGS72"; } else if( ABS(dfSemiMajor-6378137.0) < 0.01 && ABS(dfInvFlattening-298.257223563) < 0.000001 ) { pszPROJ4Ellipse = "WGS84"; } else if( EQUAL(pszDatum,"North_American_Datum_1927") ) {// pszPROJ4Ellipse = "clrk66:+datum=nad27"; /* NAD 27 */ pszPROJ4Ellipse = "clrk66"; } else if( EQUAL(pszDatum,"North_American_Datum_1983") ) {// pszPROJ4Ellipse = "GRS80:+datum=nad83"; /* NAD 83 */ pszPROJ4Ellipse = "GRS80"; } if( pszPROJ4Ellipse == NULL ) sprintf( szProj4+strlen(szProj4), "+a=%.16g +b=%.16g ", GetSemiMajor(), GetSemiMinor() ); else sprintf( szProj4+strlen(szProj4), "+ellps=%s ", pszPROJ4Ellipse );/* -------------------------------------------------------------------- *//* Translate the datum. *//* -------------------------------------------------------------------- */ const char *pszPROJ4Datum = NULL; const OGR_SRSNode *poTOWGS84 = GetAttrNode( "TOWGS84" ); char szTOWGS84[256]; if( pszDatum == NULL ) /* nothing */; else if( EQUAL(pszDatum,SRS_DN_NAD27) ) pszPROJ4Datum = "+datum=NAD27"; else if( EQUAL(pszDatum,SRS_DN_NAD83) ) pszPROJ4Datum = "+datum=NAD83"; else if( EQUAL(pszDatum,SRS_DN_WGS84) ) pszPROJ4Datum = "+datum=WGS84"; else if( poTOWGS84 != NULL ) { if( poTOWGS84->GetChildCount() > 2 && (poTOWGS84->GetChildCount() < 6 || EQUAL(poTOWGS84->GetChild(3)->GetValue(),"") && EQUAL(poTOWGS84->GetChild(4)->GetValue(),"") && EQUAL(poTOWGS84->GetChild(5)->GetValue(),"") && EQUAL(poTOWGS84->GetChild(6)->GetValue(),"")) ) { sprintf( szTOWGS84, "+towgs84=%s,%s,%s", poTOWGS84->GetChild(0)->GetValue(), poTOWGS84->GetChild(1)->GetValue(), poTOWGS84->GetChild(2)->GetValue() ); pszPROJ4Datum = szTOWGS84; } else if( poTOWGS84->GetChildCount() > 6 ) { sprintf( szTOWGS84, "+towgs84=%s,%s,%s,%s,%s,%s,%s", poTOWGS84->GetChild(0)->GetValue(), poTOWGS84->GetChild(1)->GetValue(), poTOWGS84->GetChild(2)->GetValue(), poTOWGS84->GetChild(3)->GetValue(), poTOWGS84->GetChild(4)->GetValue(), poTOWGS84->GetChild(5)->GetValue(), poTOWGS84->GetChild(6)->GetValue() ); pszPROJ4Datum = szTOWGS84; } } if( pszPROJ4Datum != NULL ) { strcat( szProj4, pszPROJ4Datum ); strcat( szProj4, " " ); }/* -------------------------------------------------------------------- *//* Is there prime meridian info to apply? *//* -------------------------------------------------------------------- */ if( poPRIMEM != NULL && poPRIMEM->GetChildCount() >= 2 && atof(poPRIMEM->GetChild(1)->GetValue()) != 0.0 ) { const char *pszAuthority = GetAuthorityName( "PRIMEM" ); char szPMValue[128]; int nCode = -1; if( pszAuthority != NULL && EQUAL(pszAuthority,"EPSG") ) nCode = atoi(GetAuthorityCode( "PRIMEM" )); switch( nCode ) { case 8902: strcpy( szPMValue, "lisbon" ); break; case 8903: strcpy( szPMValue, "paris" ); break; case 8904: strcpy( szPMValue, "bogota" ); break; case 8905: strcpy( szPMValue, "madrid" ); break; case 8906: strcpy( szPMValue, "rome" ); break; case 8907: strcpy( szPMValue, "bern" ); break; case 8908: strcpy( szPMValue, "jakarta" ); break; case 8909: strcpy( szPMValue, "ferro" ); break; case 8910: strcpy( szPMValue, "brussels" ); break; case 8911: strcpy( szPMValue, "stockholm" ); break; case 8912: strcpy( szPMValue, "athens" ); break; case 8913: strcpy( szPMValue, "oslo" ); break; default: sprintf( szPMValue, "%.16g", dfFromGreenwich ); } sprintf( szProj4+strlen(szProj4), "+pm=%s ", szPMValue ); } /* -------------------------------------------------------------------- *//* Handle linear units. *//* -------------------------------------------------------------------- */ const char *pszPROJ4Units=NULL; char *pszLinearUnits = NULL; double dfLinearConv; dfLinearConv = GetLinearUnits( &pszLinearUnits ); if( strstr(szProj4,"longlat") != NULL ) pszPROJ4Units = NULL; else if( dfLinearConv == 1.0 ) pszPROJ4Units = "m"; else if( dfLinearConv == 1000.0 ) pszPROJ4Units = "km"; else if( dfLinearConv == 0.0254 ) pszPROJ4Units = "in"; else if( EQUAL(pszLinearUnits,SRS_UL_FOOT) ) pszPROJ4Units = "ft"; else if( EQUAL(pszLinearUnits,"IYARD") || dfLinearConv == 0.9144 ) pszPROJ4Units = "yd"; else if( dfLinearConv == 0.001 ) pszPROJ4Units = "mm"; else if( dfLinearConv == 0.01 ) pszPROJ4Units = "cm"; else if( EQUAL(pszLinearUnits,SRS_UL_US_FOOT) ) pszPROJ4Units = "us-ft"; else if( EQUAL(pszLinearUnits,SRS_UL_NAUTICAL_MILE) ) pszPROJ4Units = "kmi"; else if( EQUAL(pszLinearUnits,"Mile") || EQUAL(pszLinearUnits,"IMILE") ) pszPROJ4Units = "mi"; else { sprintf( szProj4+strlen(szProj4), "+to_meter=%.16g ", dfLinearConv ); } if( pszPROJ4Units != NULL ) sprintf( szProj4+strlen(szProj4), "+units=%s ", pszPROJ4Units );/* -------------------------------------------------------------------- *//* Add the no_defs flag to ensure that no values from *//* proj_def.dat are implicitly used with our definitions. *//* -------------------------------------------------------------------- */ sprintf( szProj4+strlen(szProj4), "+no_defs " ); *ppszProj4 = CPLStrdup( szProj4 ); return OGRERR_NONE;}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -