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

📄 ogr_srs_proj4.cpp

📁 在linux环境下
💻 CPP
📖 第 1 页 / 共 4 页
字号:
    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 + -