亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? ogr_srs_xml.cpp

?? mitab,讀取MapInfo的地圖文件
?? CPP
?? 第 1 頁 / 共 4 頁
字號:
/************************************************************************/
/*                         getNormalizedValue()                         */
/*                                                                      */
/*      Parse a node to get it's numerical value, and then normalize    */
/*      into meters of degrees depending on the measure type.           */
/************************************************************************/

static double getNormalizedValue( CPLXMLNode *psNode, const char *pszPath,
                                  const char * /*pszMeasure*/, 
                                  double dfDefault )

{
    CPLXMLNode *psTargetNode;
    CPLXMLNode *psValueNode;

    if( pszPath == NULL || strlen(pszPath) == 0 )
        psTargetNode = psNode;
    else
        psTargetNode = CPLGetXMLNode( psNode, pszPath );
    
    if( psTargetNode == NULL )
        return dfDefault;

    for( psValueNode = psTargetNode->psChild; 
         psValueNode != NULL && psValueNode->eType != CXT_Text;
         psValueNode = psValueNode->psNext ) {}

    if( psValueNode == NULL )
        return dfDefault;
    
    // Add normalization later.

    return atof(psValueNode->pszValue);
}

/************************************************************************/
/*                        importGeogCSFromXML()                         */
/************************************************************************/

static OGRErr importGeogCSFromXML( OGRSpatialReference *poSRS, 
                                   CPLXMLNode *psCRS )

{
    const char     *pszGeogName, *pszDatumName, *pszEllipsoidName, *pszPMName;
    double         dfSemiMajor, dfInvFlattening, dfPMOffset = 0.0;

/* -------------------------------------------------------------------- */
/*      Set the GEOGCS name from the srsName.                           */
/* -------------------------------------------------------------------- */
    pszGeogName = 
        CPLGetXMLValue( psCRS, "srsName", "Unnamed GeogCS" );

/* -------------------------------------------------------------------- */
/*      If we don't seem to have a detailed coordinate system           */
/*      definition, check if we can define based on an EPSG code.       */
/* -------------------------------------------------------------------- */
    CPLXMLNode     *psDatum;

    psDatum = CPLGetXMLNode( psCRS, "usesGeodeticDatum.GeodeticDatum" );

    if( psDatum == NULL )
    {
        OGRSpatialReference oIdSRS;

        oIdSRS.SetLocalCS( "dummy" );
        importXMLAuthority( psCRS, &oIdSRS, "srsID", "LOCAL_CS" );

        if( oIdSRS.GetAuthorityCode( "LOCAL_CS" ) != NULL
            && oIdSRS.GetAuthorityName( "LOCAL_CS" ) != NULL
            && EQUAL(oIdSRS.GetAuthorityName("LOCAL_CS"),"EPSG") )
        {
            return poSRS->importFromEPSG( 
                atoi(oIdSRS.GetAuthorityCode("LOCAL_CS")) );
        }
    }

/* -------------------------------------------------------------------- */
/*      Get datum name.                                                 */
/* -------------------------------------------------------------------- */
    pszDatumName = 
        CPLGetXMLValue( psDatum, "datumName", "Unnamed Datum" );

/* -------------------------------------------------------------------- */
/*      Get ellipsoid information.                                      */
/* -------------------------------------------------------------------- */
    CPLXMLNode *psE;

    psE = CPLGetXMLNode( psDatum, "usesEllipsoid.Ellipsoid" );
    pszEllipsoidName = 
        CPLGetXMLValue( psE, "ellipsoidName", "Unnamed Ellipsoid" );

    dfSemiMajor = getNormalizedValue( psE, "semiMajorAxis", "Linear", 
                                      SRS_WGS84_SEMIMAJOR );

    dfInvFlattening = 
        getNormalizedValue( psE, "secondDefiningParameter.inverseFlattening", 
                            "Unitless", 0.0 );

    if( dfInvFlattening == 0.0 )
    {
        CPLError( CE_Failure, CPLE_AppDefined, 
                  "Ellipsoid inverseFlattening corrupt or missing." );
        return OGRERR_CORRUPT_DATA;
    }

/* -------------------------------------------------------------------- */
/*      Get the prime meridian.                                         */
/* -------------------------------------------------------------------- */
    CPLXMLNode *psPM;

    psPM = CPLGetXMLNode( psDatum, "usesPrimeMeridian.PrimeMeridian" );
    if( psPM == NULL )
    {
        pszPMName = "Greenwich";
        dfPMOffset = 0.0;
    }
    else
    {
        pszPMName = CPLGetXMLValue( psPM, "meridianName", 
                                    "Unnamed Prime Meridian");
        dfPMOffset = 
            getNormalizedValue( psPM, "greenwichLongitude.angle",
                                "Angular", 0.0 );
    }

/* -------------------------------------------------------------------- */
/*      Set the geographic definition.                                  */
/* -------------------------------------------------------------------- */
    poSRS->SetGeogCS( pszGeogName, pszDatumName, 
                      pszEllipsoidName, dfSemiMajor, dfInvFlattening, 
                      pszPMName, dfPMOffset );

/* -------------------------------------------------------------------- */
/*      Look for angular units.  We don't check that all axes match     */
/*      at this time.                                                   */
/* -------------------------------------------------------------------- */
#ifdef notdef
    CPLXMLNode *psAxis;

    psAxis = CPLGetXMLNode( psGeo2DCRS, 
                            "EllipsoidalCoordinateSystem.CoordinateAxis" );
    importXMLUnits( psAxis, "AngularUnit", poSRS, "GEOGCS" );
#endif

/* -------------------------------------------------------------------- */
/*      Can we set authorities for any of the levels?                   */
/* -------------------------------------------------------------------- */
    importXMLAuthority( psCRS, poSRS, "srsID", "GEOGCS" );
    importXMLAuthority( psDatum, poSRS, "datumID", "GEOGCS|DATUM" );
    importXMLAuthority( psE, poSRS, "ellipsoidID", 
                        "GEOGCS|DATUM|SPHEROID" );
    importXMLAuthority( psDatum, poSRS, 
                        "usesPrimeMeridian.PrimeMeridian.meridianID",
                        "GEOGCS|PRIMEM" );

    poSRS->Fixup();
    
    return OGRERR_NONE;
}

/************************************************************************/
/*                        importProjCSFromXML()                         */
/************************************************************************/

static OGRErr importProjCSFromXML( OGRSpatialReference *poSRS, 
                                   CPLXMLNode *psCRS )

{
    CPLXMLNode *psSubXML;
    OGRErr eErr;

/* -------------------------------------------------------------------- */
/*      Setup the PROJCS node with a name.                              */
/* -------------------------------------------------------------------- */
    poSRS->SetProjCS( CPLGetXMLValue( psCRS, "srsName", "Unnamed" ) );

/* -------------------------------------------------------------------- */
/*      Get authority information if available.  If we got it, and      */
/*      we seem to be lacking inline definition values, try and         */
/*      define according to the EPSG code for the PCS.                  */
/* -------------------------------------------------------------------- */
    importXMLAuthority( psCRS, poSRS, "srsID", "PROJCS" );

    if( poSRS->GetAuthorityCode( "PROJCS" ) != NULL
        && poSRS->GetAuthorityName( "PROJCS" ) != NULL
        && EQUAL(poSRS->GetAuthorityName("PROJCS"),"EPSG")
        && (CPLGetXMLNode( psCRS, "definedByConversion.Conversion" ) == NULL
            || CPLGetXMLNode( psCRS, "baseCRS.GeographicCRS" ) == NULL) )
    {
        return poSRS->importFromEPSG( atoi(poSRS->GetAuthorityCode("PROJCS")) );
    }

/* -------------------------------------------------------------------- */
/*      Try to set the GEOGCS info.                                     */
/* -------------------------------------------------------------------- */
    
    psSubXML = CPLGetXMLNode( psCRS, "baseCRS.GeographicCRS" );
    if( psSubXML != NULL )
    {
        eErr = importGeogCSFromXML( poSRS, psSubXML );
        if( eErr != OGRERR_NONE )
            return eErr;
    }

/* -------------------------------------------------------------------- */
/*      Get the conversion node.  It should be the only child of the    */
/*      definedByConversion node.                                       */
/* -------------------------------------------------------------------- */
    CPLXMLNode *psConv = NULL;

    psConv = CPLGetXMLNode( psCRS, "definedByConversion.Conversion" );
    if( psConv == NULL || psConv->eType != CXT_Element )
    {
        CPLError( CE_Failure, CPLE_AppDefined,
                  "Unable to find a conversion node under the definedByConversion\n"
                  "node of the ProjectedCRS." );
        return OGRERR_CORRUPT_DATA;
    }

/* -------------------------------------------------------------------- */
/*      Determine the conversion method in effect.                      */
/* -------------------------------------------------------------------- */
    int nMethod = getEPSGObjectCodeValue( CPLGetXMLNode( psConv, "usesMethod"),
                                          "method", 0 );
    
/* -------------------------------------------------------------------- */
/*      Transverse Mercator.                                            */
/* -------------------------------------------------------------------- */
    if( nMethod == 9807 ) 
    {
        poSRS->SetTM( 
            getProjectionParm( psConv, 8801, "Angular", 0.0 ), 
            getProjectionParm( psConv, 8802, "Angular", 0.0 ), 
            getProjectionParm( psConv, 8805, "Unitless", 1.0 ), 
            getProjectionParm( psConv, 8806, "Linear", 0.0 ),
            getProjectionParm( psConv, 8807, "Linear", 0.0 ) );
    }

/* -------------------------------------------------------------------- */
/*      Didn't recognise?                                               */
/* -------------------------------------------------------------------- */
    else
    {
        CPLError( CE_Failure, CPLE_AppDefined,
                  "Conversion method %d not recognised.", 
                  nMethod );
        return OGRERR_CORRUPT_DATA;
    }


/* -------------------------------------------------------------------- */
/*      Cleanup and return.                                             */
/* -------------------------------------------------------------------- */
    poSRS->Fixup();

    // Need to get linear units here!

    return OGRERR_NONE;
}

/************************************************************************/
/*                           importFromXML()                            */
/************************************************************************/

OGRErr OGRSpatialReference::importFromXML( const char *pszXML )

{
    CPLXMLNode *psTree;
    OGRErr  eErr = OGRERR_UNSUPPORTED_SRS;

    this->Clear();
        
/* -------------------------------------------------------------------- */
/*      Parse the XML.                                                  */
/* -------------------------------------------------------------------- */
    psTree = CPLParseXMLString( pszXML );
    
    if( psTree == NULL )
        return OGRERR_CORRUPT_DATA;

    CPLStripXMLNamespace( psTree, "gml", TRUE );

/* -------------------------------------------------------------------- */
/*      Import according to the root node type.  We walk through        */
/*      root elements as there is sometimes prefix stuff like           */
/*      <?xml>.                                                         */
/* -------------------------------------------------------------------- */
    CPLXMLNode *psNode = psTree;

    for( psNode = psTree; psNode != NULL; psNode = psNode->psNext )
    {
        if( EQUAL(psNode->pszValue,"GeographicCRS") )
        {
            eErr = importGeogCSFromXML( this, psNode );
            break;
        }
        
        else if( EQUAL(psNode->pszValue,"ProjectedCRS") )
        {
            eErr = importProjCSFromXML( this, psNode );
            break;
        }
    }

    CPLDestroyXMLNode( psTree );

    return eErr;
}

/************************************************************************/
/*                          OSRImportFromXML()                          */
/************************************************************************/

OGRErr OSRImportFromXML( OGRSpatialReferenceH hSRS, const char *pszXML )

{
    return ((OGRSpatialReference *) hSRS)->importFromXML( pszXML );
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
在线观看国产精品网站| 欧美日韩大陆一区二区| 亚洲一区免费观看| 午夜精品久久久久久不卡8050| 日本不卡在线视频| 成人精品在线视频观看| 在线91免费看| 国产精品久久综合| 久久99精品久久久久久动态图| 99国内精品久久| 26uuu精品一区二区| 一区二区三区久久久| 精东粉嫩av免费一区二区三区| 在线观看亚洲专区| 中文字幕在线观看不卡| 国产综合一区二区| 欧美一区二区福利视频| 亚洲午夜免费福利视频| av在线不卡电影| 精品国产三级电影在线观看| 午夜久久久久久久久久一区二区| 成人免费毛片片v| 欧美精品一区二区三区很污很色的| 亚洲国产精品欧美一二99| 91网站最新地址| 欧美国产激情一区二区三区蜜月| 麻豆极品一区二区三区| 精品视频1区2区| 亚洲最大成人网4388xx| 一本在线高清不卡dvd| 国产精品久久二区二区| 成人黄色小视频在线观看| 日韩精品一区国产麻豆| 日本一区中文字幕| 亚洲欧美日韩国产一区二区三区 | 91成人免费网站| 国产日韩欧美高清在线| 国内外成人在线视频| 欧美电视剧免费观看| 美国三级日本三级久久99| 91麻豆精品国产91久久久| 亚洲成人精品影院| 欧美精品日韩综合在线| 日韩成人av影视| 精品久久久久久久久久久久久久久 | 久久99国产精品免费网站| 4438成人网| 免费观看一级欧美片| 欧美一级黄色录像| 奇米在线7777在线精品| 欧美变态tickle挠乳网站| 久久9热精品视频| 国产亚洲综合在线| 成人18视频在线播放| 亚洲欧洲制服丝袜| 欧美三级视频在线| 蜜臀精品一区二区三区在线观看| 26uuuu精品一区二区| 国产成人综合在线观看| 亚洲伦在线观看| 国产在线视频精品一区| 精品国产一区二区三区忘忧草| 国产高清不卡二三区| 亚洲欧美一区二区三区国产精品 | 亚洲特黄一级片| 在线观看一区二区精品视频| 日韩—二三区免费观看av| 欧美r级电影在线观看| www.亚洲精品| 日韩不卡一区二区三区| 久久精品亚洲精品国产欧美| 日本久久精品电影| 精品一区二区在线视频| 国产精品萝li| 欧美一区二区在线不卡| 成人中文字幕在线| 日韩福利电影在线| 亚洲日本在线看| 精品国产精品网麻豆系列 | 国产美女在线观看一区| 亚洲人精品午夜| 91精品国产综合久久久久久久久久 | 欧美三级日韩在线| 成人一区二区三区视频在线观看| 亚洲尤物在线视频观看| 国产亚洲欧美色| 欧美视频精品在线观看| 国产成人综合网| 日韩欧美电影一区| 色婷婷av一区| 国产不卡一区视频| 日韩av一区二区三区四区| 国产精品女主播av| 欧美tk—视频vk| 欧美日韩成人综合天天影院 | 日日摸夜夜添夜夜添国产精品| 久久久精品免费网站| 欧美熟乱第一页| 成人va在线观看| 国产综合成人久久大片91| 亚洲国产色一区| 亚洲天堂久久久久久久| 国产欧美1区2区3区| 欧美大片一区二区| 欧美一区二区三区系列电影| 欧美三级视频在线播放| 色噜噜夜夜夜综合网| kk眼镜猥琐国模调教系列一区二区| 欧美aaa在线| 天天色天天爱天天射综合| 日韩毛片在线免费观看| 欧美高清在线一区| 久久久综合激的五月天| 日韩精品一区二区三区四区视频| 欧美日韩精品一区视频| 日本精品一级二级| 91蝌蚪国产九色| 972aa.com艺术欧美| 成人动漫在线一区| 国产成人综合视频| 国产成人亚洲综合色影视| 国产精品自拍网站| 国产精品2024| 成人深夜福利app| 中文字幕中文字幕一区| 国产精品久久久久毛片软件| 国产欧美日韩中文久久| 中文字幕av一区 二区| 中文字幕免费观看一区| 一色屋精品亚洲香蕉网站| 中文字幕中文乱码欧美一区二区 | 欧美日韩久久久一区| 538在线一区二区精品国产| 欧美精品v国产精品v日韩精品| 欧美区一区二区三区| 欧美午夜理伦三级在线观看| 4438成人网| 国产亚洲一区二区在线观看| 久久亚洲一区二区三区明星换脸| 久久久久久久久一| 中文字幕中文在线不卡住| 亚洲综合激情网| 亚洲妇熟xx妇色黄| 蜜桃久久精品一区二区| 国产99久久久久久免费看农村| 99国产精品久久久久久久久久 | 国产一区二区在线观看视频| 国产一区二区成人久久免费影院 | 久久精品综合网| 亚洲欧洲精品天堂一级 | 亚洲欧洲综合另类| 日韩 欧美一区二区三区| 国产伦精品一区二区三区免费| 99久久精品一区| 欧美美女激情18p| 久久精品人人做人人爽97| 亚洲丝袜美腿综合| 亚洲欧美偷拍另类a∨色屁股| 日本一区二区免费在线| 亚洲自拍偷拍av| 精品一区二区综合| 一本大道综合伊人精品热热 | 亚洲高清视频在线| 久久国产精品露脸对白| 丁香啪啪综合成人亚洲小说 | 亚洲一二三区在线观看| 国产美女久久久久| 欧美日韩日日摸| 国产精品你懂的在线| 免费在线观看日韩欧美| 91一区二区在线观看| 精品国精品自拍自在线| 亚洲色图视频网站| 经典三级在线一区| 欧美日韩国产美女| 亚洲人吸女人奶水| 国产成人av电影在线| 欧美精品乱码久久久久久| 国产精品入口麻豆九色| 捆绑调教一区二区三区| 欧美日韩在线观看一区二区| 亚洲国产精品ⅴa在线观看| 日韩av电影天堂| 欧美日韩免费观看一区三区| 中文字幕一区二区不卡| 国产一区二区在线观看视频| 日韩一区二区精品| 亚洲一区精品在线| 91免费看视频| 久久精品这里都是精品| 免费成人av在线播放| 欧美日韩日日摸| 亚洲一区二区三区激情| 91在线免费视频观看| 日本一区二区三区四区| 91免费版在线| 国产不卡视频在线播放| 国产亚洲成av人在线观看导航| 蜜臀av性久久久久蜜臀av麻豆| 精品视频1区2区|